-
Notifications
You must be signed in to change notification settings - Fork 141
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Flint async api doc #2387
Closed
+201
−0
Closed
Flint async api doc #2387
Changes from all commits
Commits
Show all changes
7 commits
Select commit
Hold shift + click to select a range
611aa7e
add 2.11 release notes
YANG-DB 2b4ab28
add 2.11 release notes
YANG-DB 61f96c8
update notes
YANG-DB cd147d4
Merge branch 'opensearch-project:main' into main
YANG-DB d40304d
add _async_query api doc and swagger
YANG-DB dc5f3b0
add _async_query api doc and swagger
YANG-DB 9db4bd2
make JsonVisitorImpl private
YANG-DB File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,109 @@ | ||
# Async Query Interface API Documentation | ||
|
||
The Async Query Interface API enables the execution of queries on top of a Spark engine. This is specifically designed to work with the `S3Glue` data source connector and allows queries to be run asynchronously. | ||
|
||
The Async Query Interface is especially useful for running complex, time-consuming queries without blocking the main thread. The API provides endpoints for query creation, result retrieval, and query cancellation. | ||
|
||
--- | ||
|
||
## Table of Contents | ||
1. [Configurations](#configurations) | ||
2. [Async Query Creation](#async-query-creation) | ||
3. [Query Result Retrieval](#query-result-retrieval) | ||
4. [Query Cancellation](#query-cancellation) | ||
5. [API Mock Tests](#api-mock-tests) | ||
|
||
--- | ||
|
||
## Configurations | ||
|
||
Before using the Async Query APIs, the Spark Execution Engine Config for Async Queries must be set under `plugins.query.executionengine.spark.config` in the cluster settings. For more details on this configuration, refer to the introductory section of this document. | ||
|
||
--- | ||
|
||
## Async Query Creation | ||
|
||
To create an async query, you can use the `POST /_plugins/_async_query` endpoint. | ||
|
||
**Examples** | ||
|
||
- Query Creation Sample Request | ||
``` | ||
POST _plugins/_async_query | ||
{"query":""CREATE EXTERNAL TABLE mys3.default.http_logs ( | ||
`@timestamp` TIMESTAMP, | ||
clientip STRING, | ||
request STRING, | ||
status INT, | ||
size INT, | ||
year INT, | ||
month INT, | ||
day INT) | ||
USING json PARTITIONED BY(year, month, day) OPTIONS (path 's3://flint-data-dp-eu-west-1-beta/data/http_log/http_logs_partitioned_json_bz2/', compression 'bzip2')"" | ||
,"datasource":"mys3","lang":"sql"} | ||
``` | ||
|
||
|
||
## Query Result Retrieval | ||
|
||
To fetch the result of a previously created async query, use the `GET /_plugins/_async_query/{queryId}` endpoint. | ||
|
||
**Examples** | ||
|
||
- Query Result Sample Request | ||
``` | ||
POST _plugins/_async_query | ||
{"query":"SELECT * FROM mys3.default.aws_elb","datasource":"mys3","lang":"sql"} | ||
``` | ||
|
||
--- | ||
|
||
## Query Cancellation | ||
|
||
To cancel a running or queued query, use the `DELETE /_plugins/_async_query/{queryId}` endpoint. | ||
|
||
**Examples** | ||
|
||
- Query Cancellation Sample Request | ||
|
||
``` | ||
DELETE _plugins/_async_query/VjlvWTNBbE1Lem15czM= | ||
``` | ||
|
||
--- | ||
|
||
_This API is designed to work seamlessly with AWS EMRServerless as the Spark execution engine._ | ||
|
||
--- | ||
|
||
## API Mock Tests | ||
|
||
The [Swagger YAML file](swagger.yaml) describes the API. You can visualize the REST API using any of the numerous [online editors](https://editor.swagger.io/). | ||
|
||
### Setup Mock Server | ||
|
||
To test the API, you can use a Swagger-based mock library like Stoplight Prism. | ||
|
||
#### Running the Swagger Mock Server | ||
|
||
```bash | ||
npm install -g @stoplight/prism-cli | ||
``` | ||
|
||
Once installed, run the server using: | ||
|
||
```bash | ||
prism mock swagger.yaml | ||
``` | ||
|
||
#### Running the Swagger Mock Server as Docker | ||
|
||
Run the following one-liner Docker command: | ||
|
||
```bash | ||
docker run -p 9200:4010 -v "$(pwd)/docs/API:/api" --name integ-prism -t stoplight/prism mock -h 0.0.0.0 /api/swagger.yaml | ||
``` | ||
|
||
After the server has started, you can initiate a CURL request to test any of the API endpoints. | ||
|
||
![Swagger API Screenshot](../../img/swagger-api.png) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,92 @@ | ||
openapi: "3.0.0" | ||
info: | ||
title: "Async Query Interface Endpoints" | ||
version: "1.0.0" | ||
|
||
paths: | ||
/_plugins/_async_query: | ||
post: | ||
summary: "Create an async query" | ||
description: "If the security plugin is enabled, this API can only be invoked by users with specific permissions." | ||
requestBody: | ||
required: true | ||
content: | ||
application/json: | ||
schema: | ||
type: object | ||
properties: | ||
datasource: | ||
type: string | ||
lang: | ||
type: string | ||
query: | ||
type: string | ||
sessionId: | ||
type: string | ||
responses: | ||
"200": | ||
description: "Query created successfully" | ||
content: | ||
application/json: | ||
schema: | ||
type: object | ||
properties: | ||
queryId: | ||
type: string | ||
sessionId: | ||
type: string | ||
|
||
/_plugins/_async_query/{queryId}: | ||
get: | ||
summary: "Fetch async query result" | ||
description: "If the security plugin is enabled, this API can only be invoked by users with specific permissions." | ||
parameters: | ||
- in: path | ||
name: queryId | ||
required: true | ||
schema: | ||
type: string | ||
responses: | ||
"200": | ||
description: "Query result" | ||
content: | ||
application/json: | ||
schema: | ||
type: object | ||
properties: | ||
status: | ||
type: string | ||
schema: | ||
type: array | ||
items: | ||
type: object | ||
properties: | ||
name: | ||
type: string | ||
type: | ||
type: string | ||
datarows: | ||
type: array | ||
items: | ||
type: array | ||
items: | ||
type: string | ||
total: | ||
type: integer | ||
size: | ||
type: integer | ||
|
||
delete: | ||
summary: "Cancel async query" | ||
description: "If the security plugin is enabled, this API can only be invoked by users with specific permissions." | ||
parameters: | ||
- in: path | ||
name: queryId | ||
required: true | ||
schema: | ||
type: string | ||
responses: | ||
"200": | ||
description: "Query cancelled successfully" | ||
servers: | ||
- url: "http://my-backend-opensearch:9200" |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we add enum here for status?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
sure