05-taosbenchmark.md 22.6 KB
Newer Older
D
dingbo 已提交
1 2 3
---
title: taosBenchmark
sidebar_label: taosBenchmark
4
toc_max_heading_level: 4
5
description: "taosBenchmark (曾用名 taosdemo ) 是一个用于测试 TDengine 产品性能的工具"
D
dingbo 已提交
6 7 8 9
---

## 简介

10 11 12 13
taosBenchmark (曾用名 taosdemo ) 是一个用于测试 TDengine 产品性能的工具。taosBenchmark 可以测试 TDengine 的插入、查询和订阅等功能的性能,它可以模拟由大量设备产生的大量数据,还可以灵活地控制数据库、超级表、标签列的数量和类型、数据列的数量和类型、子表的数量、每张子表的数据量、插入数据的时间间隔、taosBenchmark 的工作线程数量、是否以及如何插入乱序数据等。为了兼容过往用户的使用习惯,安装包提供 了 taosdemo 作为 taosBenchmark 的软链接。

## 安装

Z
zhaoyanggh 已提交
14 15
taosBenchmark 有两种安装方式:

G
gccgdb1234 已提交
16
- 安装 TDengine 官方安装包的同时会自动安装 taosBenchmark, 详情请参考[ TDengine 安装](/operation/pkg-install)
Z
zhaoyanggh 已提交
17

G
gccgdb1234 已提交
18
- 单独编译 taos-tools 并安装, 详情请参考 [taos-tools](https://github.com/taosdata/taos-tools) 仓库。
19 20 21 22 23

## 运行

### 配置和运行方式

G
gccgdb1234 已提交
24
taosBenchmark 支持两种配置方式:[命令行参数](#命令行参数详解)[JSON 配置文件](#配置文件参数详解)。这两种方式是互斥的,在使用配置文件时只能使用一个命令行参数 `-f <json file>` 指定配置文件。在使用命令行参数运行 taosBenchmark 并控制其行为时则不能使用 `-f` 参数而要用其它参数来进行配置。除此之外,taosBenchmark 还提供了一种特殊的运行方式,即无参数运行。
25 26 27 28 29 30 31 32 33 34 35 36 37

taosBenchmark 支持对 TDengine 做完备的性能测试,其所支持的 TDengine 功能分为三大类:写入、查询和订阅。这三种功能之间是互斥的,每次运行 taosBenchmark 只能选择其中之一。值得注意的是,所要测试的功能类型在使用命令行配置方式时是不可配置的,命令行配置方式只能测试写入性能。若要测试 TDegnine 的查询和订阅性能,必须使用配置文件的方式,通过配置文件中的参数 `filetype` 指定所要测试的功能类型。

**在运行 taosBenchmark 之前要确保 TDengine 集群已经在正确运行。**

### 无命令行参数运行

执行下列命令即可快速体验 taosBenchmark 对 TDengine 进行基于默认配置的写入性能测试。

```bash
taosBenchmark
```

Z
zhaoyanggh 已提交
38
在无参数运行时,taosBenchmark 默认连接 `/etc/taos` 下指定的 TDengine 集群,并在 TDengine 中创建一个名为 test 的数据库,test 数据库下创建名为 meters 的一张超级表,超级表下创建 10000 张表,每张表中写入 10000 条记录。注意,如果已有 test 数据库,这个命令会先删除该数据库后建立一个全新的 test 数据库。
39 40 41 42 43 44

### 使用命令行配置参数运行

在使用命令行参数运行 taosBenchmark 并控制其行为时,`-f <json file>` 参数不能使用。所有配置参数都必须通过命令行指定。以下是使用命令行方式测试 taosBenchmark 写入性能的一个示例。

```bash
Z
zhaoyanggh 已提交
45
taosBenchmark -I stmt -n 200 -t 100
46 47
```

G
gccgdb1234 已提交
48
上面的命令 `taosBenchmark` 将创建一个名为`test`的数据库,在其中建立一张超级表`meters`,在该超级表中建立 100 张子表并使用参数绑定的方式为每张子表插入 200 条记录。
49 50 51

### 使用配置文件运行

Z
zhaoyanggh 已提交
52
taosBenchmark 安装包中提供了配置文件的示例,位于 `<install_directory>/examples/taosbenchmark-json`
53 54 55 56 57 58 59 60 61 62 63 64

使用如下命令行即可运行 taosBenchmark 并通过配置文件控制其行为。

```bash
taosBenchmark -f <json file>
```

**下面是几个配置文件的示例:**

#### 插入场景 JSON 配置文件示例

<details>
G
gccgdb1234 已提交
65
<summary>insert.json</summary>
D
dingbo 已提交
66 67

```json
68
{{#include /taos-tools/example/insert.json}}
D
dingbo 已提交
69 70
```

71 72 73 74 75
</details>

#### 查询场景 JSON 配置文件示例

<details>
G
gccgdb1234 已提交
76
<summary>query.json</summary>
D
dingbo 已提交
77 78

```json
79
{{#include /taos-tools/example/query.json}}
D
dingbo 已提交
80 81
```

82 83 84 85 86
</details>

#### 订阅场景 JSON 配置文件示例

<details>
G
gccgdb1234 已提交
87
<summary>subscribe.json</summary>
D
dingbo 已提交
88 89

```json
90
{{#include /taos-tools/example/subscribe.json}}
D
dingbo 已提交
91 92
```

93
</details>
D
dingbo 已提交
94

95
## 命令行参数详解
D
dingbo 已提交
96

97 98
- **-f/--file <json file\>** :
  要使用的 JSON 配置文件,由该文件指定所有参数,本参数与命令行其他参数不能同时使用。没有默认值。
G
gccgdb1234 已提交
99

100 101
- **-c/--config-dir <dir\>** :
  TDengine 集群配置文件所在的目录,默认路径是 /etc/taos 。
D
dingbo 已提交
102

103
- **-h/--host <host\>** :
Z
zhaoyanggh 已提交
104
  指定要连接的 TDengine 服务端的 FQDN,默认值为 localhost 。
G
gccgdb1234 已提交
105

106
- **-P/--port <port\>** :
Z
zhaoyanggh 已提交
107
  要连接的 TDengine 服务器的端口号,默认值为 6030 。
D
dingbo 已提交
108

109
- **-I/--interface <insertMode\>** :
Z
zhaoyanggh 已提交
110
  插入模式,可选项有 taosc, rest, stmt, sml, sml-rest, 分别对应普通写入、restful 接口写入、参数绑定接口写入、schemaless 接口写入、restful schemaless 接口写入 (由 taosAdapter 提供)。默认值为 taosc。
G
gccgdb1234 已提交
111

112
- **-u/--user <user\>** :
Z
zhaoyanggh 已提交
113
  用于连接 TDengine 服务端的用户名,默认为 root 。
D
dingbo 已提交
114

115 116
- **-p/--password <passwd\>** :
  用于连接 TDengine 服务端的密码,默认值为 taosdata。
G
gccgdb1234 已提交
117

118 119
- **-o/--output <file\>** :
  结果输出文件的路径,默认值为 ./output.txt。
D
dingbo 已提交
120

121
- **-T/--thread <threadNum\>** :
Z
zhaoyanggh 已提交
122
  插入数据的线程数量,默认为 8 。
G
gccgdb1234 已提交
123

124 125
- **-B/--interlace-rows <rowNum\>** :
  启用交错插入模式并同时指定向每个子表每次插入的数据行数。交错插入模式是指依次向每张子表插入由本参数所指定的行数并重复这个过程,直到所有子表的数据都插入完成。默认值为 0, 即向一张子表完成数据插入后才会向下一张子表进行数据插入。
D
dingbo 已提交
126

127 128
- **-i/--insert-interval <timeInterval\>** :
  指定交错插入模式的插入间隔,单位为 ms,默认值为 0。 只有当 `-B/--interlace-rows` 大于 0 时才起作用。意味着数据插入线程在为每个子表插入隔行扫描记录后,会等待该值指定的时间间隔后再进行下一轮写入。
G
gccgdb1234 已提交
129

130 131
- **-r/--rec-per-req <rowNum\>** :
  每次向 TDegnine 请求写入的数据行数,默认值为 30000 。
D
dingbo 已提交
132

133 134
- **-t/--tables <tableNum\>** :
  指定子表的数量,默认为 10000 。
G
gccgdb1234 已提交
135

136 137
- **-S/--timestampstep <stepLength\>** :
  每个子表中插入数据的时间戳步长,单位是 ms,默认值是 1。
D
dingbo 已提交
138

139 140
- **-n/--records <recordNum\>** :
  每个子表插入的记录数,默认值为 10000 。
G
gccgdb1234 已提交
141

142 143
- **-d/--database <dbName\>** :
  所使用的数据库的名称,默认值为 test 。
D
dingbo 已提交
144

145
- **-b/--data-type <colType\>** :
Z
zhaoyanggh 已提交
146
  超级表的数据列的类型。如果不使用则默认为有三个数据列,其类型分别为 FLOAT, INT, FLOAT 。
G
gccgdb1234 已提交
147

148
- **-l/--columns <colNum\>** :
Z
zhaoyanggh 已提交
149
  超级表的数据列的总数量。如果同时设置了该参数和 `-b/--data-type`,则最后的结果列数为两者取大。如果本参数指定的数量大于 `-b/--data-type` 指定的列数,则未指定的列类型默认为 INT, 例如: `-l 5 -b float,double`, 那么最后的列为 `FLOAT,DOUBLE,INT,INT,INT`。如果 columns 指定的数量小于或等于 `-b/--data-type` 指定的列数,则结果为 `-b/--data-type` 指定的列和类型,例如: `-l 3 -b float,double,float,bigint`,那么最后的列为 `FLOAT,DOUBLE,FLOAT,BIGINT`
D
dingbo 已提交
150

151 152
- **-A/--tag-type <tagType\>** :
  超级表的标签列类型。nchar 和 binary 类型可以同时设置长度,例如:
G
gccgdb1234 已提交
153

154 155 156
```
taosBenchmark -A INT,DOUBLE,NCHAR,BINARY(16)
```
D
dingbo 已提交
157

158 159
如果没有设置标签类型,默认是两个标签,其类型分别为 INT 和 BINARY(16)。
注意:在有的 shell 比如 bash 命令里面 “()” 需要转义,则上述指令应为:
G
gccgdb1234 已提交
160

161 162 163
```
taosBenchmark -A INT,DOUBLE,NCHAR,BINARY\(16\)
```
D
dingbo 已提交
164

165 166
- **-w/--binwidth <length\>**:
  nchar 和 binary 类型的默认长度,默认值为 64。
G
gccgdb1234 已提交
167

168 169
- **-m/--table-prefix <tablePrefix\>** :
  子表名称的前缀,默认值为 "d"。
D
dingbo 已提交
170

171 172
- **-E/--escape-character** :
  开关参数,指定在超级表和子表名称中是否使用转义字符。默认值为不使用。
G
gccgdb1234 已提交
173

174 175
- **-C/--chinese** :
  开关参数,指定 nchar 和 binary 是否使用 Unicode 中文字符。默认值为不使用。
D
dingbo 已提交
176

177 178
- **-N/--normal-table** :
  开关参数,指定只创建普通表,不创建超级表。默认值为 false。仅当插入模式为 taosc, stmt, rest 模式下可以使用。
G
gccgdb1234 已提交
179

180 181
- **-M/--random** :
  开关参数,插入数据为生成的随机值。默认值为 false。若配置此参数,则随机生成要插入的数据。对于数值类型的 标签列/数据列,其值为该类型取值范围内的随机值。对于 NCHAR 和 BINARY 类型的 标签列/数据列,其值为指定长度范围内的随机字符串。
D
dingbo 已提交
182

183 184
- **-x/--aggr-func** :
  开关参数,指示插入后查询聚合函数。默认值为 false。
G
gccgdb1234 已提交
185

186 187
- **-y/--answer-yes** :
  开关参数,要求用户在提示后确认才能继续。默认值为 false 。
D
dingbo 已提交
188

189
- **-O/--disorder <Percentage\>** :
Z
zhaoyanggh 已提交
190
  指定乱序数据的百分比概率,其值域为 [0,50]。默认为 0,即没有乱序数据。
G
gccgdb1234 已提交
191

192 193
- **-R/--disorder-range <timeRange\>** :
  指定乱序数据的时间戳回退范围。所生成的乱序时间戳为非乱序情况下应该使用的时间戳减去这个范围内的一个随机值。仅在 `-O/--disorder` 指定的乱序数据百分比大于 0 时有效。
D
dingbo 已提交
194

195
- **-F/--prepare_rand <Num\>** :
196
  生成的随机数据中唯一值的数量。若为 1 则表示所有数据都相同。默认值为 10000 。
D
dingbo 已提交
197

198 199
- **-a/--replica <replicaNum\>** :
  创建数据库时指定其副本数,默认值为 1 。
G
gccgdb1234 已提交
200

201 202
- **-V/--version** :
  显示版本信息并退出。不能与其它参数混用。
D
dingbo 已提交
203

204 205
- **-?/--help** :
  显示帮助信息并退出。不能与其它参数混用。
G
gccgdb1234 已提交
206

207
## 配置文件参数详解
G
gccgdb1234 已提交
208

209
### 通用配置参数
G
gccgdb1234 已提交
210

211
本节所列参数适用于所有功能模式。
G
gccgdb1234 已提交
212

213 214
- **filetype** : 要测试的功能,可选值为 `insert`, `query``subscribe`。分别对应插入、查询和订阅功能。每个配置文件中只能指定其中之一。
- **cfgdir** : TDengine 集群配置文件所在的目录,默认路径是 /etc/taos 。
D
dingbo 已提交
215

216
- **host** : 指定要连接的 TDengine 服务端的 FQDN,默认值为 localhost。
G
gccgdb1234 已提交
217

218
- **port** : 要连接的 TDengine 服务器的端口号,默认值为 6030。
219

Z
zhaoyanggh 已提交
220
- **user** : 用于连接 TDengine 服务端的用户名,默认为 root。
G
gccgdb1234 已提交
221

222
- **password** : 用于连接 TDengine 服务端的密码,默认值为 taosdata。
223

224
### 插入场景配置参数
G
gccgdb1234 已提交
225

Z
zhaoyanggh 已提交
226
插入场景下 `filetype` 必须设置为 `insert`,该参数及其它通用参数详见[通用配置参数](#通用配置参数)
227

228
#### 数据库相关配置参数
G
gccgdb1234 已提交
229

230
创建数据库时的相关参数在 json 配置文件中的 `dbinfo` 中配置,具体参数如下。这些参数与 TDengine 中 `create database` 时所指定的数据库参数相对应。
231

Z
zhaoyanggh 已提交
232
- **name** : 数据库名。
G
gccgdb1234 已提交
233

Z
zhaoyanggh 已提交
234
- **drop** : 插入前是否删除数据库,默认为 true。
235

Z
zhaoyanggh 已提交
236
- **replica** : 创建数据库时指定的副本数。
G
gccgdb1234 已提交
237

Z
zhaoyanggh 已提交
238
- **days** : 单个数据文件中存储数据的时间跨度,默认值为 10。
G
gccgdb1234 已提交
239

Z
zhaoyanggh 已提交
240
- **cache** : 缓存块的大小,单位是 MB,默认值是 16。
G
gccgdb1234 已提交
241

Z
zhaoyanggh 已提交
242
- **blocks** : 每个 vnode 中缓存块的数量,默认为 6。
243

Z
zhaoyanggh 已提交
244
- **precision** : 数据库时间精度,默认值为 "ms"。
G
gccgdb1234 已提交
245

Z
zhaoyanggh 已提交
246
- **keep** : 保留数据的天数,默认值为 3650。
247

Z
zhaoyanggh 已提交
248
- **minRows** : 文件块中的最小记录数,默认值为 100。
G
gccgdb1234 已提交
249

Z
zhaoyanggh 已提交
250
- **maxRows** : 文件块中的最大记录数,默认值为 4096。
251

Z
zhaoyanggh 已提交
252
- **comp** : 文件压缩标志,默认值为 2。
G
gccgdb1234 已提交
253

Z
zhaoyanggh 已提交
254
- **walLevel** : WAL 级别,默认为 1。
255

Z
zhaoyanggh 已提交
256
- **cacheLast** : 是否允许将每个表的最后一条记录保留在内存中,默认值为 0,可选值为 0,1,2,3。
G
gccgdb1234 已提交
257

Z
zhaoyanggh 已提交
258
- **quorum** : 多副本模式下的写确认数量,默认值为 1。
259

Z
zhaoyanggh 已提交
260
- **fsync** : 当 wal 设置为 2 时,fsync 的间隔时间,单位为 ms,默认值为 3000。
G
gccgdb1234 已提交
261

Z
zhaoyanggh 已提交
262
- **update** : 是否支持数据更新,默认值为 0, 可选值为 0, 1, 2。
263

264
#### 超级表相关配置参数
G
gccgdb1234 已提交
265

266
创建超级表时的相关参数在 json 配置文件中的 `super_tables` 中配置,具体参数如下表。
267

268
- **name**: 超级表名,必须配置,没有默认值。
Z
zhaoyanggh 已提交
269
- **child_table_exists** : 子表是否已经存在,默认值为 "no",可选值为 "yes" 或 "no"。
G
gccgdb1234 已提交
270

Z
zhaoyanggh 已提交
271
- **child_table_count** : 子表的数量,默认值为 10。
272

Z
zhaoyanggh 已提交
273
- **child_table_prefix** : 子表名称的前缀,必选配置项,没有默认值。
274

Z
zhaoyanggh 已提交
275
- **escape_character** : 超级表和子表名称中是否包含转义字符,默认值为 "no",可选值为 "yes" 或 "no"。
G
gccgdb1234 已提交
276

Z
zhaoyanggh 已提交
277
- **auto_create_table** : 仅当 insert_mode 为 taosc, rest, stmt 并且 childtable_exists 为 "no" 时生效,该参数为 "yes" 表示 taosBenchmark 在插入数据时会自动创建不存在的表;为 "no" 则表示先提前建好所有表再进行插入。
278

279
- **batch_create_tbl_num** : 创建子表时每批次的建表数量,默认为 10。注:实际的批数不一定与该值相同,当执行的 SQL 语句大于支持的最大长度时,会自动截断再执行,继续创建。
280

Z
zhaoyanggh 已提交
281
- **data_source** : 数据的来源,默认为 taosBenchmark 随机产生,可以配置为 "rand" 和 "sample"。为 "sample" 时使用 sample_file 参数指定的文件内的数据。
282

283
- **insert_mode** : 插入模式,可选项有 taosc, rest, stmt, sml, sml-rest, 分别对应普通写入、restful 接口写入、参数绑定接口写入、schemaless 接口写入、restful schemaless 接口写入 (由 taosAdapter 提供)。默认值为 taosc 。
284

285
- **non_stop_mode** : 指定是否持续写入,若为 "yes" 则 insert_rows 失效,直到 Ctrl + C 停止程序,写入才会停止。默认值为 "no",即写入指定数量的记录后停止。注:即使在持续写入模式下 insert_rows 失效,但其也必须被配置为一个非零正整数。
286

287
- **line_protocol** : 使用行协议插入数据,仅当 insert_mode 为 sml 或 sml-rest 时生效,可选项为 line, telnet, json。
288

289
- **tcp_transfer** : telnet 模式下的通信协议,仅当 insert_mode 为 sml-rest 并且 line_protocol 为 telnet 时生效。如果不配置,则默认为 http 协议。
290

291
- **insert_rows** : 每个子表插入的记录数,默认为 0 。
292

293 294 295 296 297
- **childtable_offset** : 仅当 childtable_exists 为 yes 时生效,指定从超级表获取子表列表时的偏移量,即从第几个子表开始。

- **childtable_limit** : 仅当 childtable_exists 为 yes 时生效,指定从超级表获取子表列表的上限。

- **interlace_rows** : 启用交错插入模式并同时指定向每个子表每次插入的数据行数。交错插入模式是指依次向每张子表插入由本参数所指定的行数并重复这个过程,直到所有子表的数据都插入完成。默认值为 0, 即向一张子表完成数据插入后才会向下一张子表进行数据插入。
298

299 300 301 302
- **insert_interval** : 指定交错插入模式的插入间隔,单位为 ms,默认值为 0。 只有当 `-B/--interlace-rows` 大于 0 时才起作用。意味着数据插入线程在为每个子表插入隔行扫描记录后,会等待该值指定的时间间隔后再进行下一轮写入。

- **partial_col_num** : 若该值为正数 n 时, 则仅向前 n 列写入,仅当 insert_mode 为 taosc 和 rest 时生效,如果 n 为 0 则是向全部列写入。

Z
zhaoyanggh 已提交
303
- **disorder_ratio** : 指定乱序数据的百分比概率,其值域为 [0,50]。默认为 0,即没有乱序数据。
304 305 306

- **disorder_range** : 指定乱序数据的时间戳回退范围。所生成的乱序时间戳为非乱序情况下应该使用的时间戳减去这个范围内的一个随机值。仅在 `-O/--disorder` 指定的乱序数据百分比大于 0 时有效。

Z
zhaoyanggh 已提交
307
- **timestamp_step** : 每个子表中插入数据的时间戳步长,单位与数据库的 `precision` 一致,默认值是 1。
308 309 310 311 312 313 314 315 316 317

- **start_timestamp** : 每个子表的时间戳起始值,默认值是 now。

- **sample_format** : 样本数据文件的类型,现在只支持 "csv" 。

- **sample_file** : 指定 csv 格式的文件作为数据源,仅当 data_source 为 sample 时生效。若 csv 文件内的数据行数小于等于 prepared_rand,那么会循环读取 csv 文件数据直到与 prepared_rand 相同;否则则会只读取 prepared_rand 个数的行的数据。也即最终生成的数据行数为二者取小。

- **use_sample_ts** : 仅当 data_source 为 sample 时生效,表示 sample_file 指定的 csv 文件内是否包含第一列时间戳,默认为 no。 若设置为 yes, 则使用 csv 文件第一列作为时间戳,由于同一子表时间戳不能重复,生成的数据量取决于 csv 文件内的数据行数相同,此时 insert_rows 失效。

- **tags_file** : 仅当 insert_mode 为 taosc, rest 的模式下生效。 最终的 tag 的数值与 childtable_count 有关,如果 csv 文件内的 tag 数据行小于给定的子表数量,那么会循环读取 csv 文件数据直到生成 childtable_count 指定的子表数量;否则则只会读取 childtable_count 行 tag 数据。也即最终生成的子表数量为二者取小。
318 319 320 321 322

#### 标签列与数据列配置参数

指定超级表标签列与数据列的配置参数分别在 `super_tables` 中的 `columns``tag` 中。

323
- **type** : 指定列类型,可选值请参考 TDengine 支持的数据类型。
G
gccgdb1234 已提交
324
  注:JSON 数据类型比较特殊,只能用于标签,当使用 JSON 类型作为 tag 时有且只能有这一个标签,此时 count 和 len 代表的意义分别是 JSON tag 内的 key-value pair 的个数和每个 KV pair 的 value 的值的长度,value 默认为 string。
325 326 327 328 329

- **len** : 指定该数据类型的长度,对 NCHAR,BINARY 和 JSON 数据类型有效。如果对其他数据类型配置了该参数,若为 0 , 则代表该列始终都是以 null 值写入;如果不为 0 则被忽略。

- **count** : 指定该类型列连续出现的数量,例如 "count": 4096 即可生成 4096 个指定类型的列。

Z
zhaoyanggh 已提交
330
- **name** : 列的名字,若与 count 同时使用,比如 "name":"current", "count":3, 则 3 个列的名字分别为 current, current_2. current_3。
331 332 333 334 335 336

- **min** : 数据类型的 列/标签 的最小值。

- **max** : 数据类型的 列/标签 的最大值。

- **values** : nchar/binary 列/标签的值域,将从值中随机选择。
337 338 339

#### 插入行为配置参数

340 341 342 343 344 345 346 347 348
- **thread_count** : 插入数据的线程数量,默认为 8。

- **connection_pool_size** : 预先建立的与 TDengine 服务端之间的连接的数量。若不配置,则与所指定的线程数相同。

- **result_file** : 结果输出文件的路径,默认值为 ./output.txt。

- **confirm_parameter_prompt** : 开关参数,要求用户在提示后确认才能继续。默认值为 false 。

- **interlace_rows** : 启用交错插入模式并同时指定向每个子表每次插入的数据行数。交错插入模式是指依次向每张子表插入由本参数所指定的行数并重复这个过程,直到所有子表的数据都插入完成。默认值为 0, 即向一张子表完成数据插入后才会向下一张子表进行数据插入。
G
gccgdb1234 已提交
349
`super_tables` 中也可以配置该参数,若配置则以 `super_tables` 中的配置为高优先级,覆盖全局设置。
350 351

- **insert_interval** :
G
gccgdb1234 已提交
352 353
  指定交错插入模式的插入间隔,单位为 ms,默认值为 0。 只有当 `-B/--interlace-rows` 大于 0 时才起作用。意味着数据插入线程在为每个子表插入隔行扫描记录后,会等待该值指定的时间间隔后再进行下一轮写入。
`super_tables` 中也可以配置该参数,若配置则以 `super_tables` 中的配置为高优先级,覆盖全局设置。
354 355

- **num_of_records_per_req** :
G
gccgdb1234 已提交
356
  每次向 TDegnine 请求写入的数据行数,默认值为 30000 。当其设置过大时,TDegnine 客户端驱动会返回相应的错误信息,此时需要调低这个参数的设置以满足写入要求。
357 358

- **prepare_rand** : 生成的随机数据中唯一值的数量。若为 1 则表示所有数据都相同。默认值为 10000 。
359 360 361 362 363 364

### 查询场景配置参数

查询场景下 `filetype` 必须设置为 `qeury`,该参数及其它通用参数详见[通用配置参数](#通用配置参数)

#### 执行指定查询语句的配置参数
G
gccgdb1234 已提交
365

366
查询子表或者普通表的配置参数在 `specified_table_query` 中设置。
G
gccgdb1234 已提交
367

Z
zhaoyanggh 已提交
368
- **query_interval** : 查询时间间隔,单位是秒,默认值为 0。
369

Z
zhaoyanggh 已提交
370
- **threads** : 执行查询 SQL 的线程数,默认值为 1。
371 372

- **sqls**
Z
zhaoyanggh 已提交
373 374
  - **sql**: 执行的 SQL 命令,必填。
  - **result**: 保存查询结果的文件,未指定则不保存。
375 376

#### 查询超级表的配置参数
G
gccgdb1234 已提交
377

378
查询超级表的配置参数在 `super_table_query` 中设置。
G
gccgdb1234 已提交
379

Z
zhaoyanggh 已提交
380
- **stblname** : 指定要查询的超级表的名称,必填。
381

Z
zhaoyanggh 已提交
382
- **query_interval** : 查询时间间隔,单位是秒,默认值为 0。
383

Z
zhaoyanggh 已提交
384
- **threads** : 执行查询 SQL 的线程数,默认值为 1。
385 386 387

- **sqls**
  - **sql** : 执行的 SQL 命令,必填;对于超级表的查询 SQL,在 SQL 命令中保留 "xxxx",程序会自动将其替换为超级表的所有子表名。
G
gccgdb1234 已提交
388
    替换为超级表中所有的子表名。
Z
zhaoyanggh 已提交
389
  - **result** : 保存查询结果的文件,未指定则不保存。
390 391

### 订阅场景配置参数
G
gccgdb1234 已提交
392

Z
zhaoyanggh 已提交
393
订阅场景下 `filetype` 必须设置为 `subscribe`,该参数及其它通用参数详见[通用配置参数](#通用配置参数)
394 395

#### 执行指定订阅语句的配置参数
G
gccgdb1234 已提交
396

397
订阅子表或者普通表的配置参数在 `specified_table_query` 中设置。
G
gccgdb1234 已提交
398

Z
zhaoyanggh 已提交
399
- **threads** : 执行 SQL 的线程数,默认为 1。
400

Z
zhaoyanggh 已提交
401
- **interva** : 执行订阅的时间间隔,单位为秒,默认为 0。
402

Z
zhaoyanggh 已提交
403
- **restart** : "yes" 表示开始新的订阅,"no" 表示继续之前的订阅,默认值为 "no"。
404

Z
zhaoyanggh 已提交
405
- **keepProgress** : "yes" 表示保留订阅进度,"no" 表示不保留,默认值为 "no"。
406

Z
zhaoyanggh 已提交
407
- **resubAfterConsume** : "yes" 表示取消之前的订阅然后再次订阅, "no" 表示继续之前的订阅,默认值为 "no"。
408 409

- **sqls**
Z
zhaoyanggh 已提交
410 411
  - **sql** : 执行的 SQL 命令,必填。
  - **result** : 保存查询结果的文件,未指定则不保存。
412 413

#### 订阅超级表的配置参数
G
gccgdb1234 已提交
414

415
订阅超级表的配置参数在 `super_table_query` 中设置。
G
gccgdb1234 已提交
416

Z
zhaoyanggh 已提交
417
- **stblname** : 要订阅的超级表名称,必填。
418

Z
zhaoyanggh 已提交
419
- **threads** : 执行 SQL 的线程数,默认为 1。
420

Z
zhaoyanggh 已提交
421
- **interva** : 执行订阅的时间间隔,单位为秒,默认为 0。
422

Z
zhaoyanggh 已提交
423
- **restart** : "yes" 表示开始新的订阅,"no" 表示继续之前的订阅,默认值为 "no"。
424

Z
zhaoyanggh 已提交
425
- **keepProgress** : "yes" 表示保留订阅进度,"no" 表示不保留,默认值为 "no"。
426

Z
zhaoyanggh 已提交
427
- **resubAfterConsume** : "yes" 表示取消之前的订阅然后再次订阅, "no" 表示继续之前的订阅,默认值为 "no"。
428 429 430

- **sqls**
  - **sql** : 执行的 SQL 命令,必填;对于超级表的查询 SQL,在 SQL 命令中保留 "xxxx",程序会自动将其替换为超级表的所有子表名。
G
gccgdb1234 已提交
431
    替换为超级表中所有的子表名。
Z
zhaoyanggh 已提交
432
  - **result** : 保存查询结果的文件,未指定则不保存。