客户端数据包
| value | name | description |
|---|---|---|
| 0 | Hello | 客户端握手开始 |
| 1 | Query | 查询请求 |
| 2 | Data | 包含数据的数据块 |
| 3 | Cancel | 取消查询 |
| 4 | Ping | Ping 请求 |
| 5 | TableStatus | 表状态请求 |
Data 可以被压缩。
Hello
例如,假设我们使用支持 54451 协议版本的 Go Client v1.10,
并希望以 default 用户、secret 密码连接到 default 数据库。
| field | type | value | description |
|---|---|---|---|
| client_name | String | "Go Client" | 客户端实现名称 |
| version_major | UVarInt | 1 | 客户端主版本号 |
| version_minor | UVarInt | 10 | 客户端次版本号 |
| protocol_version | UVarInt | 54451 | TCP 协议版本 |
| database | String | "default" | 数据库名称 |
| username | String | "default" | 用户名 |
| password | String | "secret" | 密码 |
Protocol version
协议版本是客户端使用的 TCP 协议版本。
通常它等于最新的兼容服务器修订版本号,但不要将两者混为一谈。
Defaults
所有值都应显式设置,服务器端没有默认值。
在客户端侧,可以将 "default" 数据库、"default" 用户名以及 ""(空字符串)
密码作为默认值。
查询
| 字段 | 类型 | 示例值 | 描述 |
|---|---|---|---|
| query_id | String | 1ff-a123 | 查询 ID,可为 UUIDv4 |
| client_info | ClientInfo | 见类型定义 | 客户端信息 |
| settings | Settings | 见类型定义 | 设置列表 |
| secret | String | secret | 服务器间共享密钥 |
| stage | UVarInt | 2 | 执行直到指定查询阶段 |
| compression | UVarInt | 0 | 0=禁用,1=启用 |
| body | String | SELECT 1 | 查询文本 |
客户端信息
| 字段 | 类型 | 描述 |
|---|---|---|
| query_kind | byte | None=0, Initial=1, Secondary=2 |
| initial_user | String | 初始用户 |
| initial_query_id | String | 初始查询 ID |
| initial_address | String | 初始地址 |
| initial_time | Int64 | 初始时间 |
| interface | byte | TCP=1, HTTP=2 |
| os_user | String | 操作系统用户 |
| client_hostname | String | 客户端主机名 |
| client_name | String | 客户端名称 |
| version_major | UVarInt | 客户端主版本号 |
| version_minor | UVarInt | 客户端次版本号 |
| protocol_version | UVarInt | 客户端协议版本 |
| quota_key | String | 配额键 |
| distributed_depth | UVarInt | 分布式深度 |
| version_patch | UVarInt | 客户端补丁版本 |
| otel | Bool | 是否存在 Trace 字段 |
| trace_id | FixedString(16) | Trace ID |
| span_id | FixedString(8) | Span ID |
| trace_state | String | Trace 状态 |
| trace_flags | Byte | Trace 标志 |
设置
| 字段 | 类型 | 示例值 | 描述 |
|---|---|---|---|
| key | String | send_logs_level | 设置键 |
| value | String | trace | 设置值 |
| important | Bool | true | 是否可以被忽略 |
编码为列表;当 key 和 value 为空时表示列表结束。
阶段
| 值 | 名称 | 描述 |
|---|---|---|
| 0 | FetchColumns | 仅获取列类型 |
| 1 | WithMergeableState | 执行到可合并状态为止 |
| 2 | Complete | 执行到完全完成(应为默认值) |
数据
| field | type | description |
|---|---|---|
| info | BlockInfo | 编码后的块信息 |
| columns | UVarInt | 列数 |
| rows | UVarInt | 行数 |
| columns | []Column | 包含数据的列 |
列
| field | type | value | description |
|---|---|---|---|
| name | String | foo | 列名 |
| type | String | DateTime64(9) | 列类型 |
| data | bytes | ~ | 列数据 |
取消
无数据包主体。服务器应取消该查询。
Ping
无数据包正文。服务器应返回 pong 响应。