HTTP API
GreptimeDB 提供了 HTTP API 用于与数据库进行交互。如需查看完整的 API 端点列表,请查看 HTTP Endpoints。
Base URL
API Base URL 是 http(s)://{{host}}:{{port}}/。
- 对于在本地机器上运行的 GreptimeDB 实例,Base URL 是
http://localhost:4000/,默认端口配置为4000。你可以在配置文件中更改服务的 host 和 port。 - 对于 GreptimeCloud,Base URL 是
https://{{host}}/。你可以在 GreptimeCloud 控制台的 "Connection Information" 中找到 host。
在以下内容中,我们使用 http://{{API-host}}/ 作为 Base URL 来演示 API。
通用 Headers
鉴权
假设你已经正确设置了数据库鉴权,
GreptimeDB 支持 HTTP API 中内置的 Basic 鉴权机制。要设置鉴权,请按照以下步骤操作:
- 使用
<username:password>格式和Base64算法对用户名和密码进行编码。 - 将编码后的凭据附加到下列 HTTP 请求头之一中:
Authorization : Basic <base64-encoded-credentials>x-greptime-auth : Basic <base64-encoded-credentials>
以下是一个示例。如果要使用用户名 greptime_user 和密码 greptime_pwd 连接到 GreptimeDB,请使用以下命令:
curl -X POST \
-H 'Authorization: Basic Z3JlcHRpbWVfdXNlcjpncmVwdGltZV9wd2Q=' \
-H 'Content-Type: application/x-www-form-urlencoded' \
-d 'sql=show tables' \
http://localhost:4000/v1/sql
在此示例中,Z3JlcHRpbWVfdXNlcjpncmVwdGltZV9wd2Q= 表示 greptime_user:greptime_pwd 的 Base64 编码值。请确保用自己配置的用户名和密码替换它,并使用 Base64 进行编码。
注意
InfluxDB 使用自己的鉴权格式,请参阅 InfluxDB 获取详细信息。
请求超时设置
GreptimeDB 支持在 HTTP 请求中使用 X-Greptime-Timeout 请求头,用于指定数据库服务器中运行的请求超时时间。
例如,以下请求为查询设置了 120s 的超时时间:
curl -X POST \
-H 'Authorization: Basic {{authentication}}' \
-H 'X-Greptime-Timeout: 120s' \
-H 'Content-Type: application/x-www-form-urlencoded' \
-d 'sql=show tables' \
http://localhost:4000/v1/sql
Admin APIs
注意
这些 API 在 GreptimeCloud 中无法使用。
请参考 Admin APIs 接口文档以获取更多信息。
POST SQL 语句
要通过 HTTP API 向 GreptimeDB 服务器提交 SQL 语句,请使用以下格式:
curl -X POST \
-H 'Authorization: Basic {{authentication}}' \
-H 'X-Greptime-Timeout: {{time precision}}' \
-H 'Content-Type: application/x-www-form-urlencoded' \
-d 'sql={{SQL-statement}}' \
http://{{API-host}}/v1/sql
Headers
AuthorizationX-Greptime-TimeoutContent-Type:application/x-www-form-urlencoded.X-Greptime-Timezone: 当前 SQL 查询的时区。可选。请参阅时区。
Query string parameters
db: 数据库名称。可选。如果未提供,将使用默认数据库public。format: 输出格式。可选。默认为greptimedb_v1的 JSON 格式。 除了默认的 JSON 格式外,HTTP API 还允许你通过提供format查询参数来自定义输出格式,值如下:influxdb_v1: influxdb 查询 API 兼容格式。附加参数:epoch:[ns,u,µ,ms,s,m,h],返回指定精度的时间戳
csv: 以逗号分隔值格式输出csvWithNames: 以逗号分隔值格式输出,包含列名标题csvWithNamesAndTypes: 以逗号分隔值格式输出,包含列名和数据类型标题arrow: Arrow IPC 格式。附加参数:compression:zstd或lz4,默认:无压缩
table: 控制台输出的 ASCII 表格格式null: 简洁的纯文本输出,仅显示行数和执行时间,用于评估查询性能。
Body
sql: SQL 语句。必填。
响应
响应是一个 JSON 对象,包含以下字段:
output: SQL 执行结果,请参阅下面的示例以了解详细信息。execution_time_ms: 语句的执行时间(毫秒)。
示例
INSERT 语句
例如,要向数据库 public 的 monitor 表中插入数据,请使用以下命令:
curl -X POST \
-H 'Authorization: Basic {{authorization if exists}}' \
-H 'Content-Type: application/x-www-form-urlencoded' \
-d 'sql=INSERT INTO monitor VALUES ("127.0.0.1", 1667446797450, 0.1, 0.4), ("127.0.0.2", 1667446798450, 0.2, 0.3), ("127.0.0.1", 1667446798450, 0.5, 0.2)' \
http://localhost:4000/v1/sql?db=public