Query Profile Action
リクエスト
GET /rest/v2/manager/query/query_info
GET /rest/v2/manager/query/trace/{trace_id}
GET /rest/v2/manager/query/sql/{query_id}
GET /rest/v2/manager/query/profile/text/{query_id}
GET /rest/v2/manager/query/profile/graph/{query_id}
GET /rest/v2/manager/query/profile/json/{query_id}
GET /rest/v2/manager/query/profile/fragments/{query_id}
GET /rest/v2/manager/query/current_queries
GET /rest/v2/manager/query/kill/{query_id}
クエリ情報の取得
GET /rest/v2/manager/query/query_info
説明
クラスタ内の全てのfeノードのselectクエリに関する情報を取得します。
クエリパラメータ
-
query_id省略可能、返されるクエリのクエリIDを指定します。デフォルトでは全てのクエリの情報を返します。
-
search省略可能、文字列を含むクエリ情報を返すことを指定します。現在は文字列マッチングのみが実行されます。
-
is_all_node省略可能、trueの場合は全てのfeノードのクエリ情報を返し、falseの場合は現在のfeノードのクエリ情報を返します。デフォルトはtrueです。
レスポンス
{
"msg": "success",
"code": 0,
"data": {
"column_names": [
"Query ID",
"FE Node",
"Query User",
"Execution Database",
"Sql",
"Query Type",
"Start Time",
"End Time",
"Execution Duration",
"Status"
],
"rows": [
[
...
]
]
},
"count": 0
}
Doris Version 1.2以降、AdminユーザーとRootユーザーはすべてのクエリを表示できます。通常のユーザーは自分が送信したクエリのみを表示できます。
例
GET /rest/v2/manager/query/query_info
{
"msg": "success",
"code": 0,
"data": {
"column_names": [
"Query ID",
"FE Node",
"Query User",
"Execution Database",
"Sql",
"Query Type",
"Start Time",
"End Time",
"Execution Duration",
"Status"
],
"rows": [
[
"d7c93d9275334c35-9e6ac5f295a7134b",
"127.0.0.1:8030",
"root",
"default_cluster:testdb",
"select c.id, c.name, p.age, p.phone, c.date, c.cost from cost c join people p on c.id = p.id where p.age > 20 order by c.id",
"Query",
"2021-07-29 16:59:12",
"2021-07-29 16:59:12",
"109ms",
"EOF"
]
]
},
"count": 0
}
Trace IDによるQuery IDの取得
GET /rest/v2/manager/query/trace_id/{trace_id}
説明
trace idによってquery idを取得します。
Queryを実行する前に、一意のtrace idを設定してください:
set session_context="trace_id:your_trace_id";
同じSession内でQueryを実行した後、trace idを通じてquery idを取得できます。
Pathパラメータ
-
{trace_id}ユーザー固有のtrace id。
Queryパラメータ
レスポンス
{
"msg": "success",
"code": 0,
"data": "fb1d9737de914af1-a498d5c5dec638d3",
"count": 0
}
Doris バージョン 1.2 以降、admin と root ユーザーはすべてのクエリを表示できます。一般ユーザーは自分が送信した Query のみ表示できます。指定された trace id が存在しない場合や権限がない場合、Bad Request が返されます:
{
"msg": "Bad Request",
"code": 403,
"data": "error messages",
"count": 0
}
指定されたクエリのsqlとtextプロファイルを取得
GET /rest/v2/manager/query/sql/{query_id}
GET /rest/v2/manager/query/profile/text/{query_id}
Description
指定されたクエリIDのsqlとプロファイルテキストを取得します。
Path parameters
-
query_idクエリID。
Query parameters
-
is_all_nodeオプション。trueの場合、すべてのfeノードで指定されたクエリIDを検索します。falseの場合、現在接続されているfeノードで指定されたクエリIDを検索します。デフォルトはtrueです。
Response
{
"msg": "success",
"code": 0,
"data": {
"sql": ""
},
"count": 0
}
{
"msg": "success",
"code": 0,
"data": {
"profile": ""
},
"count": 0
}
Dorisバージョン1.2以降、adminとrootユーザーはすべてのクエリを表示できます。一般ユーザーは自分が送信したQueryのみ表示できます。指定されたtrace idが存在しない、または権限がない場合は、Bad Requestが返されます:
{
"msg": "Bad Request",
"code": 403,
"data": "error messages",
"count": 0
}
例
-
sqlを取得する。
GET /rest/v2/manager/query/sql/d7c93d9275334c35-9e6ac5f295a7134b
Response:
{
"msg": "success",
"code": 0,
"data": {
"sql": "select c.id, c.name, p.age, p.phone, c.date, c.cost from cost c join people p on c.id = p.id where p.age > 20 order by c.id"
},
"count": 0
}
指定されたクエリフラグメントとインスタンス情報を取得
GET /rest/v2/manager/query/profile/fragments/{query_id}
2.1.1以降、このAPIは非推奨です。http://<fe_ip>:<fe_http_port>/QueryProfileからプロファイルをダウンロードできます。
説明
指定されたクエリIDのフラグメント名、インスタンスID、ホストip/port、実行時間を取得します。
パスパラメータ
-
query_idクエリID。
クエリパラメータ
-
is_all_nodeオプション。trueの場合、すべてのfeノードで指定されたクエリIDを検索し、falseの場合、現在接続されているfeノードで指定されたクエリIDを検索します。デフォルトはtrueです。
レスポンス
{
"msg": "success",
"code": 0,
"data": [
{
"fragment_id": "",
"time": "",
"instance_id": {
"": {
"host": "",
"active_time": ""
}
}
}
],
"count": 0
}
Doris バージョン 1.2 以降、admin と root ユーザーはすべてのクエリを表示できます。一般ユーザーは自分が送信した Query のみを表示できます。指定された trace id が存在しない場合や権限がない場合は、Bad Request が返されます:
{
"msg": "Bad Request",
"code": 403,
"data": "error messages",
"count": 0
}
例
GET /rest/v2/manager/query/profile/fragments/d7c93d9275334c35-9e6ac5f295a7134b
Response:
{
"msg": "success",
"code": 0,
"data": [
{
"fragment_id": "0",
"time": "36.169ms",
"instance_id": {
"d7c93d9275334c35-9e6ac5f295a7134e": {
"host": "172.19.0.4:9060",
"active_time": "36.169ms"
}
}
},
{
"fragment_id": "1",
"time": "20.710ms",
"instance_id": {
"d7c93d9275334c35-9e6ac5f295a7134c": {
"host": "172.19.0.5:9060",
"active_time": "20.710ms"
}
}
},
{
"fragment_id": "2",
"time": "7.83ms",
"instance_id": {
"d7c93d9275334c35-9e6ac5f295a7134d": {
"host": "172.19.0.6:9060",
"active_time": "7.83ms"
},
"d7c93d9275334c35-9e6ac5f295a7134f": {
"host": "172.19.0.7:9060",
"active_time": "10.873ms"
}
}
}
],
"count": 0
}
指定されたクエリIDツリープロファイル情報を取得
GET /rest/v2/manager/query/profile/graph/{query_id}
説明
指定されたクエリIDのツリープロファイル情報を取得します。show query profileコマンドと同じです。
パスパラメータ
-
query_idクエリID。
クエリパラメータ
-
fragment_idとinstance_idオプション、両方のパラメータを指定するか、両方とも指定しないかのいずれかです。
両方とも指定されていない場合、シンプルなプロファイルツリーが返されます。これはshow query profile '/query_id'と同等です;
両方とも指定されている場合、詳細なプロファイルツリーが返されます。これはshow query profile '/query_id/fragment_id/instance_id'と同等です。 -
is_all_nodeオプション、trueの場合はすべてのfeノードで指定されたクエリIDに関する情報をクエリし、falseの場合は現在接続されているfeノードで指定されたクエリIDに関する情報をクエリします。デフォルトはtrueです。
レスポンス
{
"msg": "success",
"code": 0,
"data": {
"graph":""
},
"count": 0
}
Doris バージョン 1.2 以降、admin と root ユーザーはすべてのクエリを表示できます。一般ユーザーは自分が送信した Query のみを表示できます。指定された trace id が存在しない、または権限がない場合は、Bad Request が返されます:
{
"msg": "Bad Request",
"code": 403,
"data": "error messages",
"count": 0
}
現在実行中のクエリ
GET /rest/v2/manager/query/current_queries
説明
show proc "/current_query_stmts"と同様で、現在実行中のクエリを返します。
パスパラメータ
クエリパラメータ
-
is_all_nodeオプション。trueに設定すると、すべてのFEから現在実行中のクエリを返します。デフォルトはtrueです。
レスポンス
{
"msg": "success",
"code": 0,
"data": {
"columnNames": ["Frontend", "QueryId", "ConnectionId", "Database", "User", "ExecTime", "SqlHash", "Statement"],
"rows": [
["172.19.0.3", "108e47ab438a4560-ab1651d16c036491", "2", "", "root", "6074", "1a35f62f4b14b9d7961b057b77c3102f", "select sleep(60)"],
["172.19.0.11", "3606cad4e34b49c6-867bf6862cacc645", "3", "", "root", "9306", "1a35f62f4b14b9d7961b057b77c3102f", "select sleep(60)"]
]
},
"count": 0
}
クエリのキャンセル
POST /rest/v2/manager/query/kill/{query_id}
説明
指定された接続のクエリをキャンセルします。
パスパラメータ
-
{query_id}クエリID。クエリIDは
trance_idAPIで取得できます。
クエリパラメータ
レスポンス
{
"msg": "success",
"code": 0,
"data": null,
"count": 0
}