-
Notifications
You must be signed in to change notification settings - Fork 141
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Create Job API Signed-off-by: Vamsi Manohar <[email protected]> * Refactor to Async Query API Signed-off-by: Vamsi Manohar <[email protected]> --------- Signed-off-by: Vamsi Manohar <[email protected]>
- Loading branch information
1 parent
cda01e9
commit 71f4155
Showing
66 changed files
with
2,574 additions
and
594 deletions.
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
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
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
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
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
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
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,108 @@ | ||
.. highlight:: sh | ||
|
||
======================= | ||
Async Query Interface Endpoints | ||
======================= | ||
|
||
.. rubric:: Table of contents | ||
|
||
.. contents:: | ||
:local: | ||
:depth: 1 | ||
|
||
|
||
Introduction | ||
============ | ||
|
||
For supporting `S3Glue <../ppl/admin/connector/s3glue_connector.rst>`_ and Cloudwatch datasources connectors, we have introduced a new execution engine on top of Spark. | ||
All the queries to be executed on spark execution engine can only be submitted via Async Query APIs. Below sections will list all the new APIs introduced. | ||
|
||
|
||
Configuration required for Async Query APIs | ||
====================================== | ||
Currently, we only support AWS emr serverless as SPARK execution engine. The details of execution engine should be configured under | ||
``plugins.query.executionengine.spark.config`` cluster setting. The value should be a stringified json comprising of ``applicationId``, ``executionRoleARN``,``region``. | ||
Sample Setting Value :: | ||
|
||
plugins.query.executionengine.spark.config: '{"applicationId":"xxxxx", "executionRoleARN":"arn:aws:iam::***********:role/emr-job-execution-role","region":"eu-west-1"}' | ||
|
||
|
||
If this setting is not configured during bootstrap, Async Query APIs will be disabled and it requires a cluster restart to enable them back again. | ||
We make use of default aws credentials chain to make calls to the emr serverless application and also make sure the default credentials | ||
have pass role permissions for emr-job-execution-role mentioned in the engine configuration. | ||
|
||
|
||
|
||
Async Query Creation API | ||
====================================== | ||
If security plugin is enabled, this API can only be invoked by users with permission ``cluster:admin/opensearch/ql/async_query/create``. | ||
|
||
HTTP URI: _plugins/_query/_async_query | ||
HTTP VERB: POST | ||
|
||
|
||
|
||
Sample Request:: | ||
|
||
curl --location 'http://localhost:9200/_plugins/_async_query' \ | ||
--header 'Content-Type: application/json' \ | ||
--data '{ | ||
"kind" : "sql", | ||
"query" : "select * from my_glue.default.http_logs limit 10" | ||
}' | ||
|
||
Sample Response:: | ||
|
||
{ | ||
"queryId": "00fd796ut1a7eg0q" | ||
} | ||
|
||
Async Query Result API | ||
====================================== | ||
If security plugin is enabled, this API can only be invoked by users with permission ``cluster:admin/opensearch/ql/async_query/result``. | ||
Async Query Creation and Result Query permissions are orthogonal, so any user with result api permissions and queryId can query the corresponding query results irrespective of the user who created the async query. | ||
|
||
|
||
HTTP URI: _plugins/_query/_async_query/{queryId} | ||
HTTP VERB: GET | ||
|
||
|
||
Sample Request BODY:: | ||
|
||
curl --location --request GET 'http://localhost:9200/_plugins/_async_query/00fd796ut1a7eg0q' \ | ||
--header 'Content-Type: application/json' \ | ||
--data '{ | ||
"query" : "select * from default.http_logs limit 1" | ||
}' | ||
|
||
Sample Response if the Query is in Progress :: | ||
|
||
{"status":"RUNNING"} | ||
|
||
Sample Response If the Query is successful :: | ||
|
||
{ | ||
"schema": [ | ||
{ | ||
"name": "indexed_col_name", | ||
"type": "string" | ||
}, | ||
{ | ||
"name": "data_type", | ||
"type": "string" | ||
}, | ||
{ | ||
"name": "skip_type", | ||
"type": "string" | ||
} | ||
], | ||
"datarows": [ | ||
[ | ||
"status", | ||
"int", | ||
"VALUE_SET" | ||
] | ||
], | ||
"total": 1, | ||
"size": 1 | ||
} |
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
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
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
Oops, something went wrong.