DQL Data Query (Legacy)¶
POST /api/v1/df/query_data
Overview¶
DQL Data Query
Query Request Parameters¶
| Parameter Name | Type | Required | Description |
|---|---|---|---|
| body | string | DQL query structure Allowed to be empty: False |
|
| queries_body | string | DQL query structure (Deprecated on 2023-08-11) Allowed to be empty: False |
|
| search_after | string | Pagination query parameter (Deprecated on 2023-08-11) Allowed to be empty: False |
Parameter Additional Notes¶
Query Notes
- Query String Element Field Description
| Parameter Name | type | Required | Description |
|---|---|---|---|
| body | string | Y | Query request body |
| queries_body[*] | string | (Legacy parameter, deprecated on 2023-08-10) Query list | |
| search_after | string | (Legacy parameter, deprecated on 2023-08-10, new parameter moved to query structure) Pagination query data. The first query defaults to [], when querying more paginated data, add the search_after field from the last query result to query subsequent data |
- JSON Structure Parameter Description in body
| Parameter Name | type | Required | Description |
|---|---|---|---|
| queries | array | Y | Multi-command query, its content is a list of query objects |
| fieldTagDescNeeded | boolean | Whether field or tag description information is needed |
- queries[*] Member Parameter Structure Description
| Parameter Name | type | Required | Description |
|---|---|---|---|
| qtype | string | Y | Query statement type dql: indicates dql type query statement; promql: indicates PromQl type query statement |
| query | json | Y | Query structure |
| query.q | string | Query statement consistent with qtype, such as dql or promql query statement | |
| query.ignore_cache | boolean | Whether the query disables cache, default is false, indicating use of cache | |
| query.promqlType | enum | Effective when qtype=promql, promql query type, optional values instantQuery andrangeQuery, default value israngeQuery |
|
| query.highlight | boolean | Whether to display highlighted data | |
| query.timeRange | array | Timestamp list of time range | |
| query.disableMultipleField | bool | Whether to enable single-column mode, default is true |
|
| query.showLabel | bool | Whether to display object labels, default is none | |
| query.funcList | array | Re-aggregate and modify DQL return value, note that when disableMultipleField=Flse, this parameter is invalid | |
| query.slimit | integer | Time series group size, only effective for Metrics queries | |
| query.soffset | integer | Time series group offset | |
| query.limit | integer | Pagination size | |
| query.offset | integer | Pagination offset | |
| query.orderby | array | Sorting list, {fieldName:method} , note that Metrics query sorting only supports fieldName=time; method in ["desc", "asc"]; note that Metrics query sorting only supports fieldName=time |
|
| query.density | string | Response point density, priority is less than autoDensity and greater than density set in DQL statement | |
| query.interval | integer | Unit is seconds, time slice interval, used to calculate response points; calculated points less than or equal to density=high points are valid, otherwise invalid | |
| query.search_after | array | Pagination marker, returned by the current interface, used to pass in the next request | |
| query.maxPointCount | integer | Maximum points | |
| query.workspaceUUID | string | The uuid of the workspace to be queried, "*" means query all authorized spaces, refer to the interface /wksp_share/granted_ws_list for space reference | |
| query.workspaceUUIDs | array | The uuids of the workspaces to be queried, priority is higher than query.workspaceUUID. ["*"] means query all authorized spaces, refer to the interface /wksp_share/granted_ws_list for space reference | |
| query.targetRegion | string | When the specified query workspace is ["*"], this field is required | |
| query.output_format | string | lineprotocol: line protocol output, default is empty, default output format remains unchanged | |
| query.cursor_time | integer | Segmented query threshold: when the first segmented query is performed, cursor_time needs to be set to end_time; for subsequent segmented queries, cursor_time needs to be set to next_cursor_time in the response | |
| query.cursor_token | string | Pagination query token (returned by engine cursor_token value): when pagination querying, the next_cursor_token returned from the last query needs to be set as the cursor_token of this query; requests without cursor_token may cause data with the same timestamp to be skipped when paging. | |
| query.disable_sampling | bool | Sampling disable switch, default value is false |
- Response Point Density
densityParameter Value Description
| Optional Value | Description |
|---|---|
| lower | Lower, 60 points |
| low | Low, 180 points |
| medium | Medium, 360 points |
| high | Low, 720 points |
-
Note the priority of point density parameters, maximum density
density[high]* maxPointCount > interval > density > control parameters in DQL statement -
Common Query Notes
Note: When querying data through the openapi interface, the default role is admin. Note that it may be subject to data access rule restrictions.
Request Example¶
curl 'https://openapi.truewatch.com/api/v1/df/query_data?body=\{%22queries%22:\[\{%22uuid%22:%2205ea25f0-2fa3-11ee-aa03-57233270ef0c%22,%22qtype%22:%22dql%22,%22query%22:\{%22q%22:%22L::re(`.*`):(`*`)\{+`index`+IN+\[%27default%27\]+\}%22,%22highlight%22:true,%22limit%22:50,%22orderby%22:\[\{%22time%22:%22desc%22\}\],%22_funcList%22:\[\],%22funcList%22:\[\],%22disableMultipleField%22:false,%22align_time%22:false,%22is_optimized%22:true,%22offset%22:0,%22search_after%22:\[1690808645037,538070,%22L_1690808645037_cj3r2itnel8fnfu5tlag%22\],%22timeRange%22:\[1690807857000,1690808757999\],%22tz%22:%22Asia/Shanghai%22\}\}\],%22expensiveQueryCheck%22:true\}' \
-H 'DF-API-KEY: <DF-API-KEY>' \
--compressed
Response¶
{
"code": 200,
"content": {
"data": [
{
"AsyncTaskPayload": null,
"async_id": "",
"column_names": [
"container_id",
"source",
"filepath",
"image",
"index",
"df_metering_size",
"__namespace",
"host",
"log_read_offset",
"__docid",
"filename",
"service",
"image_name",
"image_short_name",
"image_tag",
"log_read_lines",
"message",
"log_read_time",
"container_name",
"container_type",
"message_length",
"create_time",
"container_runtime_name",
"date_ns",
"status"
],
"complete": false,
"cost": "19ms",
"index_name": "",
"index_names": "",
"index_store_type": "es",
"is_running": false,
"points": null,
"query_type": "",
"raw_query": "{\\\"aggs\\\":{},\\\"_source\\\":{\\\"excludes\\\":[\\\"message@json\\\"],\\\"includes\\\":[]},\\\"query\\\":{\\\"bool\\\":{\\\"filter\\\":[{\\\"term\\\":{\\\"__namespace\\\":\\\"logging\\\"}},{\\\"range\\\":{\\\"date\\\":{\\\"gte\\\":\\\"1680187562081\\\",\\\"lte\\\":\\\"1680230762081\\\"}}},{\\\"bool\\\":{\\\"should\\\":[{\\\"terms\\\":{\\\"index\\\":[\\\"default\\\"]}}]}}]}},\\\"size\\\":50,\\\"sort\\\":[{\\\"date\\\":{\\\"missing\\\":\\\"_last\\\",\\\"order\\\":\\\"desc\\\",\\\"unmapped_type\\\":\\\"long\\\"}},{\\\"date_ns\\\":{\\\"missing\\\":\\\"_last\\\",\\\"order\\\":\\\"desc\\\",\\\"unmapped_type\\\":\\\"long\\\"}},{\\\"__docid\\\":{\\\"missing\\\":\\\"_first\\\",\\\"order\\\":\\\"desc\\\",\\\"unmapped_type\\\":\\\"string\\\"}}],\\\"search_after\\\":[1680226330509,8572,\\\"L_1680226330509_cgj4hqbrhi85kl1m6os0\\\"],\\\"timeout\\\":\\\"54s\\\"}",
"search_after": [
1680226330508,
82936,
"L_1680226330508_cgj4hbdepb7fcn07sf60"
],
"series": [
{
"columns": [
"container_id",
"time",
"source",
"filepath",
"image",
"index",
"df_metering_size",
"__namespace",
"host",
"log_read_offset",
"__docid",
"filename",
"service",
"image_name",
"image_short_name",
"image_tag",
"log_read_lines",
"message",
"log_read_time",
"container_name",
"container_type",
"message_length",
"create_time",
"container_runtime_name",
"date_ns",
"status"
],
"values": [
[
"2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380",
1680226330509,
"test",
"/var/lib/docker/containers/2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380/2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380-json.log",
"test:test",
"default",
1,
"logging",
"izbp152ke14timzud0du15z",
149232879,
"L_1680226330509_cgj4hqbrhi85kl1m6org",
"2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380-json.log",
"test",
"test",
"test",
"test",
147890,
"ddtrace.profiling.exporter.http.UploadFailed: [Errno 101] Network is unreachable",
1680226330508872700,
"compose_python_ddtrace_web_b_1",
"docker",
80,
1680230633485,
"compose_python_ddtrace_web_b_1",
8571,
"unknown"
],
[
"2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380",
1680226330509,
"test",
"/var/lib/docker/containers/2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380/2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380-json.log",
"test:test",
"default",
1,
"logging",
"izbp152ke14timzud0du15z",
149232879,
"L_1680226330509_cgj4hqbrhi85kl1m6or0",
"2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380-json.log",
"test",
"test",
"test",
"test",
147889,
" raise retry_exc from fut.exception()",
1680226330508872700,
"compose_python_ddtrace_web_b_1",
"docker",
40,
1680230633485,
"compose_python_ddtrace_web_b_1",
8570,
"unknown"
],
[
"2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380",
1680226330509,
"test",
"/var/lib/docker/containers/2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380/2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380-json.log",
"test:test",
"default",
1,
"logging",
"izbp152ke14timzud0du15z",
149232879,
"L_1680226330509_cgj4hqbrhi85kl1m6oqg",
"2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380-json.log",
"test",
"test",
"test",
"test",
147888,
" File \\\"/usr/local/lib/python3.7/site-packages/tenacity/__init__.py\\\", line 361, in iter",
1680226330508872700,
"compose_python_ddtrace_web_b_1",
"docker",
87,
1680230633485,
"compose_python_ddtrace_web_b_1",
8569,
"unknown"
],
[
"2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380",
1680226330508,
"test",
"/var/lib/docker/containers/2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380/2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380-json.log",
"test:test",
"default",
1,
"logging",
"izbp152ke14timzud0du15z",
149228783,
"L_1680226330508_cgj4hbdepb7fcn07sf60",
"2fef685801c80b5cb7d04b7b5e859007de94752aadbe801df812a058acf5e380-json.log",
"test",
"test",
"test",
"test",
147841,
"KeyError: 'dd.service'",
1680226330507918000,
"compose_python_ddtrace_web_b_1",
"docker",
22,
1680230573234,
"compose_python_ddtrace_web_b_1",
82936,
"unknown"
]
]
}
],
"total_hits": 10000
}
]
},
"errorCode": "",
"message": "",
"success": true,
"traceId": "TRACE-CD50CBBD-E29B-4F58-BD6B-618EED50920A"
}