メインコンテンツまでスキップ

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
}
Note

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
}
Info

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
}
Info

Dorisバージョン1.2以降、adminとrootユーザーはすべてのクエリを表示できます。一般ユーザーは自分が送信したQueryのみ表示できます。指定されたtrace idが存在しない、または権限がない場合は、Bad Requestが返されます:

{
"msg": "Bad Request",
"code": 403,
"data": "error messages",
"count": 0
}

  1. 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
}
Info

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_idinstance_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
}
Info

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_id APIで取得できます。

クエリパラメータ

レスポンス

{
"msg": "success",
"code": 0,
"data": null,
"count": 0
}