05-high-volume.md 20.6 KB
Newer Older
D
dingbo 已提交
1 2 3 4 5 6
import Tabs from "@theme/Tabs";
import TabItem from "@theme/TabItem";

# 高效写入

本节介绍如何高效地向 TDengine 写入数据。
D
dingbo 已提交
7 8 9

## 高效写入原理 {#principle}

D
dingbo 已提交
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
### 客户端程序的角度 {#application-view}

从客户端程序的角度来说,高效写入数据要考虑以下几个因素:

1. 单次写入的数据量。一般来讲,每批次写入的数据量越大越高效(但超过一定阈值其优势会消失)。使用 SQL 写入 TDengine 时,尽量在一条 SQL 中拼接更多数据。目前,TDengine 支持的一条 SQL 的最大长度为 1,048,576(1M)个字符。可通过配置客户端参数 maxSQLLength(默认值为 65480)进行修改。
2. 并发连接数。一般来讲,同时写入数据的并发连接数越多写入越高效(但超过一定阈值反而会下降,取决于服务端处理能力)。
3. 数据在不同表(或子表)之间的分布,即要写入数据的相邻性。一般来说,每批次只向同一张表(或子表)写入数据比向多张表(或子表)写入数据要更高效;
4. 写入方式。一般来讲:
   - 参数绑定写入比 SQL 写入更高效。因参数绑定方式避免了 SQL 解析。(但增加了 C 接口的调用次数,对于连接器也有性能损耗)。
   - SQL 写入不自动建表比自动建表更高效。因自动建表要频繁检查表是否存在
   - SQL 写入比无模式写入更高效。因无模式写入会自动建表且支持动态更改表结构

客户端程序要充分且恰当地利用以上几个因素。在单次写入中尽量只向同一张表(或子表)写入数据,每批次写入的数据量经过测试和调优设定为一个最适合当前系统处理能力的数值,并发写入的连接数同样经过测试和调优后设定为一个最适合当前系统处理能力的数值,以实现在当前系统中的最佳写入速度。

### 数据源的角度 {#datasource-view}

客户端程序通常需要从数据源读数据再写入 TDengine。从数据源角度来说,以下几种情况需要在读线程和写线程之间增加队列:

1. 有多个数据源,单个数据源生成数据的速度远小于单线程写入的速度,但数据量整体比较大。此时队列的作用是把多个数据源的数据汇聚到一起,增加单次写入的数据量。
2. 单个数据源生成数据的速度远大于单线程写入的速度。此时队列的作用是增加写入的并发度。
3. 单张表的数据分散在多个数据源。此时队列的作用是将同一张表的数据提前汇聚到一起,提高写入时数据的相邻性。

如果写应用的数据源是 Kafka, 写应用本身即 Kafka 的消费者,则可利用 Kafka 的特性实现高效写入。比如:

1. 将同一张表的数据写到同一个 Topic 的同一个 Partition,增加数据的相邻性
2. 通过订阅多个 Topic 实现数据汇聚
3. 通过增加 Consumer 线程数增加写入的并发度
4. 通过增加每次 fetch 的最大数据量来增加单次写入的最大数据量

### 服务器配置的角度 {#setting-view}
D
dingbo 已提交
40

D
dingbo 已提交
41
从服务器配置的角度来说,也有很多优化写入性能的方法。
D
dingbo 已提交
42

D
dingbo 已提交
43
如果无论怎么调节客户端程序,taosd 进程的 CPU 使用率都很低,那很可能需要增加 vgroup 的数量。比如:数据库总表数是 1000 且 minTablesPerVnode 设置的也是 1000,那么这个数据至多有一个 vgroup。此时如果将 minTablesPerVnode 和 tablelncStepPerVnode 都设置成 100, 则这个数据库可能用到 10 个 vgroup。
D
dingbo 已提交
44

D
dingbo 已提交
45
更多调优参数,请参考[性能优化](../../operation/optimize)[配置参考](../../reference/config)部分。
D
dingbo 已提交
46

D
dingbo 已提交
47
## 高效写入示例 {#sample-code}
D
dingbo 已提交
48

D
dingbo 已提交
49 50 51 52 53
### 场景设计 {#scenario}

下面的示例程序展示了如何高效写入数据,场景设计如下:

- TDengine 客户端程序从其它数据源不断读入数据,在示例程序中采用生成模拟数据的方式来模拟读取数据源
D
dingbo 已提交
54 55 56 57
- 单个连接向 TDengine 写入的速度无法与读数据的速度相匹配,因此客户端程序启动多个线程,每个线程都建立了与 TDengine 的连接,每个线程都有一个独占的固定大小的消息队列
- 客户端程序将接收到的数据根据所属的表名(或子表名)HASH 到不同的线程,即写入该线程所对应的消息队列,以此确保属于某个表(或子表)的数据一定会被一个固定的线程处理
- 各个子线程在将所关联的消息队列中的数据读空后或者读取数据量达到一个预定的阈值后将该批数据写入 TDengine,并继续处理后面接收到的数据

D
dingbo 已提交
58 59 60 61 62 63 64 65 66 67
![TDengine 高效写入示例场景的线程模型](highvolume.webp)

### 示例代码 {#code}

这一部分是针对以上场景的示例代码。对于其它场景高效写入原理相同,不过代码需要适当修改。

本示例代码假设源数据属于同一张超级表(meters)的不同子表。程序在开始写入数据之前已经在 test 库创建了这个超级表。对于子表,将根据收到的数据,由应用程序自动创建。如果实际场景是多个超级表,只需修改写任务自动建表的代码。

<Tabs defaultValue="java" groupId="lang">
<TabItem label="Java" value="java">
D
dingbo 已提交
68

D
dingbo 已提交
69
**程序清单**
D
dingbo 已提交
70

D
dingbo 已提交
71 72 73 74 75 76 77 78 79
| 类名             | 功能说明                                                                    |
| ---------------- | --------------------------------------------------------------------------- |
| FastWriteExample | 主程序                                                                      |
| ReadTask         | 从模拟源中读取数据,将表名经过 hash 后得到 Queue 的 index,写入对应的 Queue |
| WriteTask        | 从 Queue 中获取数据,组成一个 Batch,写入 TDengine                          |
| MockDataSource   | 模拟生成一定数量 meters 子表的数据                                          |
| SQLWriter        | WriteTask 依赖这个类完成 SQL 拼接、自动建表、 SQL 写入、SQL 长度检查        |
| StmtWriter       | 实现参数绑定方式批量写入(暂未完成)                                        |
| DataBaseMonitor  | 统计写入速度,并每隔 10 秒把当前写入速度打印到控制台                        |
D
dingbo 已提交
80 81


D
dingbo 已提交
82
以下是各类的完整代码和更详细的功能说明。
D
dingbo 已提交
83

D
dingbo 已提交
84 85
<details>
<summary>FastWriteExample</summary>
D
dingbo 已提交
86 87 88 89 90 91 92 93 94 95 96 97 98 99
主程序负责:

1. 创建消息队列
2. 启动写线程
3. 启动读线程
4. 每隔 10 秒统计一次写入速度

主程序默认暴露了 4 个参数,每次启动程序都可调节,用于测试和调优:

1. 读线程个数。默认为 1。
2. 写线程个数。默认为 3。
3. 模拟生成的总表数。默认为 1000。将会平分给各个读线程。
4. 每批最多写入记录数量。默认为 3000。

D
dingbo 已提交
100
队列容量(taskQueueCapacity)也是与性能有关的参数,可通过修改程序调节。一般来讲,队列容量越大,入队被阻塞的概率越小,队列的吞吐量越大,但是内存占用也会越大。 示例程序默认值已经设置地足够大。
D
dingbo 已提交
101 102

```java
D
dingbo 已提交
103
{{#include docs/examples/java/src/main/java/com/taos/example/highvolume/FastWriteExample.java}}
D
dingbo 已提交
104 105 106 107
```

</details>

D
dingbo 已提交
108 109
<details>
<summary>ReadTask</summary>
D
dingbo 已提交
110 111 112 113 114

读任务负责从数据源读数据。每个读任务都关联了一个模拟数据源。每个模拟数据源可生成一点数量表的数据。不同的模拟数据源生成不同表的数据。

读任务采用阻塞的方式写消息队列。也就是说,一旦队列满了,写操作就会阻塞。

D
dingbo 已提交
115 116 117 118 119 120
```java
{{#include docs/examples/java/src/main/java/com/taos/example/highvolume/ReadTask.java}}
```

</details>

D
dingbo 已提交
121
<details>
D
dingbo 已提交
122
<summary>WriteTask</summary>
D
dingbo 已提交
123 124

```java
D
dingbo 已提交
125
{{#include docs/examples/java/src/main/java/com/taos/example/highvolume/WriteTask.java}}
D
dingbo 已提交
126 127 128 129 130
```

</details>

<details>
D
dingbo 已提交
131 132

<summary>MockDataSource</summary>
D
dingbo 已提交
133 134

```java
D
dingbo 已提交
135
{{#include docs/examples/java/src/main/java/com/taos/example/highvolume/MockDataSource.java}}
D
dingbo 已提交
136 137 138 139
```

</details>

D
dingbo 已提交
140 141 142
<details>

<summary>SQLWriter</summary>
D
dingbo 已提交
143

D
dingbo 已提交
144 145 146 147 148 149 150
SQLWriter 类封装了拼 SQL 和写数据的逻辑。注意,所有的表都没有提前创建,而是在 catch 到表不存在异常的时候,再以超级表为模板批量建表,然后重新执行 INSERT 语句。对于其它异常,这里简单地记录当时执行的 SQL 语句到日志中,你也可以记录更多线索到日志,已便排查错误和故障恢复。

```java
{{#include docs/examples/java/src/main/java/com/taos/example/highvolume/SQLWriter.java}}
```

</details>
D
dingbo 已提交
151 152

<details>
D
dingbo 已提交
153 154

<summary>DataBaseMonitor</summary>
D
dingbo 已提交
155 156

```java
D
dingbo 已提交
157
{{#include docs/examples/java/src/main/java/com/taos/example/highvolume/DataBaseMonitor.java}}
D
dingbo 已提交
158 159 160 161
```

</details>

D
dingbo 已提交
162
**执行步骤**
D
dingbo 已提交
163 164 165 166 167 168 169 170 171 172

<details>
<summary>执行 Java 示例程序</summary>

执行程序前需配置环境变量 `TDENGINE_JDBC_URL`。如果 TDengine Server 部署在本机,且用户名、密码和端口都是默认值,那么可配置:

```
TDENGINE_JDBC_URL="jdbc:TAOS://localhost:6030?user=root&password=taosdata"
```

D
dingbo 已提交
173
**本地集成开发环境执行示例程序**
D
dingbo 已提交
174 175 176 177 178 179 180 181 182

1. clone TDengine 仓库
   ```
   git clone git@github.com:taosdata/TDengine.git --depth 1
   ```
2. 用集成开发环境打开 `docs/examples/java` 目录。
3. 在开发环境中配置环境变量 `TDENGINE_JDBC_URL`。如果已配置了全局的环境变量 `TDENGINE_JDBC_URL` 可跳过这一步。
4. 运行类 `com.taos.example.highvolume.FastWriteExample`

D
dingbo 已提交
183
**远程服务器上执行示例程序**
D
dingbo 已提交
184 185 186 187 188 189 190 191 192 193 194 195 196

若要在服务器上执行示例程序,可按照下面的步骤操作:

1. 打包示例代码。在目录 TDengine/docs/examples/java 下执行:
   ```
   mvn package
   ```
2. 远程服务器上创建 examples 目录:
   ```
   mkdir -p examples/java
   ```
3. 复制依赖到服务器指定目录:
   - 复制依赖包,只用复制一次
D
dingbo 已提交
197 198 199
     ```
     scp -r .\target\lib <user>@<host>:~/examples/java
     ```
D
dingbo 已提交
200
   - 复制本程序的 jar 包,每次更新代码都需要复制
D
dingbo 已提交
201 202 203
     ```
     scp -r .\target\javaexample-1.0.jar <user>@<host>:~/examples/java
     ```
D
dingbo 已提交
204 205
4. 配置环境变量。
   编辑 `~/.bash_profile``~/.bashrc` 添加如下内容例如:
D
dingbo 已提交
206

D
dingbo 已提交
207 208 209
   ```
   export TDENGINE_JDBC_URL="jdbc:TAOS://localhost:6030?user=root&password=taosdata"
   ```
D
dingbo 已提交
210

D
dingbo 已提交
211 212 213
   以上使用的是本地部署 TDengine Server 时默认的 JDBC URL。你需要根据自己的实际情况更改。

5. 用 java 命令启动示例程序,命令模板:
D
dingbo 已提交
214

D
dingbo 已提交
215 216 217 218 219
   ```
   java -classpath lib/*:javaexample-1.0.jar  com.taos.example.highvolume.FastWriteExample <read_thread_count>  <white_thread_count> <total_table_count> <max_batch_size>
   ```

6. 结束测试程序。测试程序不会自动结束,在获取到当前配置下稳定的写入速度后,按 <kbd>CTRL</kbd> + <kbd>C</kbd> 结束程序。
D
dingbo 已提交
220
   下面是一次实际运行的日志输出,机器配置 16核 + 64G + 固态硬盘。
D
dingbo 已提交
221 222

   ```
D
dingbo 已提交
223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259
   root@vm85$ java -classpath lib/*:javaexample-1.0.jar  com.taos.example.highvolume.FastWriteExample 2 12
   18:56:35.896 [main] INFO  c.t.e.highvolume.FastWriteExample - readTaskCount=2, writeTaskCount=12 tableCount=1000 maxBatchSize=3000
   18:56:36.011 [WriteThread-0] INFO  c.taos.example.highvolume.WriteTask - started
   18:56:36.015 [WriteThread-0] INFO  c.taos.example.highvolume.SQLWriter - maxSQLLength=1048576
   18:56:36.021 [WriteThread-1] INFO  c.taos.example.highvolume.WriteTask - started
   18:56:36.022 [WriteThread-1] INFO  c.taos.example.highvolume.SQLWriter - maxSQLLength=1048576
   18:56:36.031 [WriteThread-2] INFO  c.taos.example.highvolume.WriteTask - started
   18:56:36.032 [WriteThread-2] INFO  c.taos.example.highvolume.SQLWriter - maxSQLLength=1048576
   18:56:36.041 [WriteThread-3] INFO  c.taos.example.highvolume.WriteTask - started
   18:56:36.042 [WriteThread-3] INFO  c.taos.example.highvolume.SQLWriter - maxSQLLength=1048576
   18:56:36.093 [WriteThread-4] INFO  c.taos.example.highvolume.WriteTask - started
   18:56:36.094 [WriteThread-4] INFO  c.taos.example.highvolume.SQLWriter - maxSQLLength=1048576
   18:56:36.099 [WriteThread-5] INFO  c.taos.example.highvolume.WriteTask - started
   18:56:36.100 [WriteThread-5] INFO  c.taos.example.highvolume.SQLWriter - maxSQLLength=1048576
   18:56:36.100 [WriteThread-6] INFO  c.taos.example.highvolume.WriteTask - started
   18:56:36.101 [WriteThread-6] INFO  c.taos.example.highvolume.SQLWriter - maxSQLLength=1048576
   18:56:36.103 [WriteThread-7] INFO  c.taos.example.highvolume.WriteTask - started
   18:56:36.104 [WriteThread-7] INFO  c.taos.example.highvolume.SQLWriter - maxSQLLength=1048576
   18:56:36.105 [WriteThread-8] INFO  c.taos.example.highvolume.WriteTask - started
   18:56:36.107 [WriteThread-8] INFO  c.taos.example.highvolume.SQLWriter - maxSQLLength=1048576
   18:56:36.108 [WriteThread-9] INFO  c.taos.example.highvolume.WriteTask - started
   18:56:36.109 [WriteThread-9] INFO  c.taos.example.highvolume.SQLWriter - maxSQLLength=1048576
   18:56:36.156 [WriteThread-10] INFO  c.taos.example.highvolume.WriteTask - started
   18:56:36.157 [WriteThread-11] INFO  c.taos.example.highvolume.WriteTask - started
   18:56:36.158 [WriteThread-10] INFO  c.taos.example.highvolume.SQLWriter - maxSQLLength=1048576
   18:56:36.158 [ReadThread-0] INFO  com.taos.example.highvolume.ReadTask - started
   18:56:36.158 [ReadThread-1] INFO  com.taos.example.highvolume.ReadTask - started
   18:56:36.158 [WriteThread-11] INFO  c.taos.example.highvolume.SQLWriter - maxSQLLength=1048576
   18:56:46.369 [main] INFO  c.t.e.highvolume.FastWriteExample - count=18554448 speed=1855444
   18:56:56.946 [main] INFO  c.t.e.highvolume.FastWriteExample - count=39059660 speed=2050521
   18:57:07.322 [main] INFO  c.t.e.highvolume.FastWriteExample - count=59403604 speed=2034394
   18:57:18.032 [main] INFO  c.t.e.highvolume.FastWriteExample - count=80262938 speed=2085933
   18:57:28.432 [main] INFO  c.t.e.highvolume.FastWriteExample - count=101139906 speed=2087696
   18:57:38.921 [main] INFO  c.t.e.highvolume.FastWriteExample - count=121807202 speed=2066729
   18:57:49.375 [main] INFO  c.t.e.highvolume.FastWriteExample - count=142952417 speed=2114521
   18:58:00.689 [main] INFO  c.t.e.highvolume.FastWriteExample - count=163650306 speed=2069788
   18:58:11.646 [main] INFO  c.t.e.highvolume.FastWriteExample - count=185019808 speed=2136950
D
dingbo 已提交
260 261 262 263
   ```

</details>

D
dingbo 已提交
264 265
</TabItem>
<TabItem label="Python" value="python">
D
dingbo 已提交
266

D
dingbo 已提交
267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283
**程序清单**

Python 示例程序中采用了多进程的架构,并使用了跨进程的消息队列。

| 函数或类                 | 功能说明                                                             |
| ------------------------ | -------------------------------------------------------------------- |
| main 函数                | 程序入口, 创建各个子进程和消息队列                                  |
| run_monitor_process 函数 | 创建数据库,超级表,统计写入速度并定时打印到控制台                   |
| run_read_task 函数       | 读进程主要逻辑,负责从其它数据系统读数据,并分发数据到为之分配的队列 |
| MockDataSource 类        | 模拟数据源, 实现迭代器接口,每次批量返回每张表的接下来 1000 条数据   |
| run_write_task 函数      | 写进程主要逻辑。每次从队列中取出尽量多的数据,并批量写入             |
| SQLWriter类              | SQL 写入和自动建表                                                   |
| StmtWriter 类            | 实现参数绑定方式批量写入(暂未完成)                                 |


<details>
<summary>main 函数</summary>
D
dingbo 已提交
284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299

main 函数负责创建消息队列和启动子进程,子进程有 3 类:

1. 1 个监控进程,负责数据库初始化和统计写入速度
2. n 个读进程,负责从其它数据系统读数据
3. m 个写进程,负责写数据库

main 函数可以接收 5 个启动参数,依次是:

1. 读任务(进程)数, 默认为 1
2. 写任务(进程)数, 默认为 1
3. 模拟生成的总表数,默认为 1000
4. 队列大小(单位字节),默认为 1000000
5. 每批最多写入记录数量, 默认为 3000

```python
D
dingbo 已提交
300
{{#include docs/examples/python/fast_write_example.py:main}}
D
dingbo 已提交
301 302 303 304
```

</details>

D
dingbo 已提交
305 306
<details>
<summary>run_monitor_process</summary>
D
dingbo 已提交
307 308 309 310

监控进程负责初始化数据库,并监控当前的写入速度。

```python
D
dingbo 已提交
311
{{#include docs/examples/python/fast_write_example.py:monitor}}
D
dingbo 已提交
312 313 314 315 316 317 318 319
```

</details>

<details>

<summary>run_read_task 函数</summary>

D
dingbo 已提交
320 321
读进程,负责从其它数据系统读数据,并分发数据到为之分配的队列。

D
dingbo 已提交
322
```python
D
dingbo 已提交
323
{{#include docs/examples/python/fast_write_example.py:read}}
D
dingbo 已提交
324 325 326 327 328
```

</details>

<details>
D
dingbo 已提交
329

D
dingbo 已提交
330 331
<summary>MockDataSource</summary>

D
dingbo 已提交
332 333
以下是模拟数据源的实现,我们假设数据源生成的每一条数据都带有目标表名信息。实际中你可能需要一定的规则确定目标表名。

D
dingbo 已提交
334
```python
D
dingbo 已提交
335
{{#include docs/examples/python/mockdatasource.py}}
D
dingbo 已提交
336 337 338 339 340 341 342
```

</details>

<details>
<summary>run_write_task 函数</summary>

D
dingbo 已提交
343 344
写进程每次从队列中取出尽量多的数据,并批量写入。

D
dingbo 已提交
345
```python
D
dingbo 已提交
346
{{#include docs/examples/python/fast_write_example.py:write}}
D
dingbo 已提交
347 348
```

D
dingbo 已提交
349
</details>
D
dingbo 已提交
350 351 352

<details>

D
dingbo 已提交
353 354
SQLWriter 类封装了拼 SQL 和写数据的逻辑。所有的表都没有提前创建,而是在发生表不存在错误的时候,再以超级表为模板批量建表,然后重新执行 INSERT 语句。对于其它错误会记录当时执行的 SQL, 以便排查错误和故障恢复。这个类也对 SQL 是否超过最大长度限制做了检查,如果接近 SQL 最大长度限制(maxSQLLength),将会立即执行 SQL。为了减少 SQL 此时,建议将 maxSQLLength 适当调大。

D
dingbo 已提交
355 356 357 358 359 360 361 362
<summary>SQLWriter</summary>

```python
{{#include docs/examples/python/sql_writer.py}}
```

</details>

D
dingbo 已提交
363
**执行步骤**
D
dingbo 已提交
364 365 366 367 368 369

<details>

<summary>执行 Python 示例程序</summary>

1. 前提条件
D
dingbo 已提交
370

D
dingbo 已提交
371 372 373 374 375
   - 已安装 TDengine 客户端驱动
   - 已安装 Python3, 推荐版本 >= 3.8
   - 已安装 taospy

2. 安装 faster-fifo 代替 python 内置的 multiprocessing.Queue
D
dingbo 已提交
376

D
dingbo 已提交
377 378 379 380
   ```
   pip3 install faster-fifo
   ```

D
dingbo 已提交
381
3. 点击上面的“查看源码”链接复制 `fast_write_example.py``sql_writer.py``mockdatasource.py` 三个文件。
D
dingbo 已提交
382 383

4. 执行示例程序
D
dingbo 已提交
384

D
dingbo 已提交
385
   ```
D
dingbo 已提交
386
   python3  fast_write_example.py <READ_TASK_COUNT> <WRITE_TASK_COUNT> <TABLE_COUNT> <QUEUE_SIZE> <MAX_BATCH_SIZE>
D
dingbo 已提交
387 388
   ```

D
dingbo 已提交
389
   下面是一次实际运行的输出, 机器配置 16核 + 64G + 固态硬盘。
D
dingbo 已提交
390

D
dingbo 已提交
391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425
   ```
   root@vm85$ python3 fast_write_example.py  8 8
   2022-07-14 19:13:45,869 [root] - READ_TASK_COUNT=8, WRITE_TASK_COUNT=8, TABLE_COUNT=1000, QUEUE_SIZE=1000000, MAX_BATCH_SIZE=3000
   2022-07-14 19:13:48,882 [root] - WriteTask-0 started with pid 718347
   2022-07-14 19:13:48,883 [root] - WriteTask-1 started with pid 718348
   2022-07-14 19:13:48,884 [root] - WriteTask-2 started with pid 718349
   2022-07-14 19:13:48,884 [root] - WriteTask-3 started with pid 718350
   2022-07-14 19:13:48,885 [root] - WriteTask-4 started with pid 718351
   2022-07-14 19:13:48,885 [root] - WriteTask-5 started with pid 718352
   2022-07-14 19:13:48,886 [root] - WriteTask-6 started with pid 718353
   2022-07-14 19:13:48,886 [root] - WriteTask-7 started with pid 718354
   2022-07-14 19:13:48,887 [root] - ReadTask-0 started with pid 718355
   2022-07-14 19:13:48,888 [root] - ReadTask-1 started with pid 718356
   2022-07-14 19:13:48,889 [root] - ReadTask-2 started with pid 718357
   2022-07-14 19:13:48,889 [root] - ReadTask-3 started with pid 718358
   2022-07-14 19:13:48,890 [root] - ReadTask-4 started with pid 718359
   2022-07-14 19:13:48,891 [root] - ReadTask-5 started with pid 718361
   2022-07-14 19:13:48,892 [root] - ReadTask-6 started with pid 718364
   2022-07-14 19:13:48,893 [root] - ReadTask-7 started with pid 718365
   2022-07-14 19:13:56,042 [DataBaseMonitor] - count=6676310 speed=667631.0
   2022-07-14 19:14:06,196 [DataBaseMonitor] - count=20004310 speed=1332800.0
   2022-07-14 19:14:16,366 [DataBaseMonitor] - count=32290310 speed=1228600.0
   2022-07-14 19:14:26,527 [DataBaseMonitor] - count=44438310 speed=1214800.0
   2022-07-14 19:14:36,673 [DataBaseMonitor] - count=56608310 speed=1217000.0
   2022-07-14 19:14:46,834 [DataBaseMonitor] - count=68757310 speed=1214900.0
   2022-07-14 19:14:57,280 [DataBaseMonitor] - count=80992310 speed=1223500.0
   2022-07-14 19:15:07,689 [DataBaseMonitor] - count=93805310 speed=1281300.0
   2022-07-14 19:15:18,020 [DataBaseMonitor] - count=106111310 speed=1230600.0
   2022-07-14 19:15:28,356 [DataBaseMonitor] - count=118394310 speed=1228300.0
   2022-07-14 19:15:38,690 [DataBaseMonitor] - count=130742310 speed=1234800.0
   2022-07-14 19:15:49,000 [DataBaseMonitor] - count=143051310 speed=1230900.0
   2022-07-14 19:15:59,323 [DataBaseMonitor] - count=155276310 speed=1222500.0
   2022-07-14 19:16:09,649 [DataBaseMonitor] - count=167603310 speed=1232700.0
   2022-07-14 19:16:19,995 [DataBaseMonitor] - count=179976310 speed=1237300.0
   ```
D
dingbo 已提交
426

B
Bo Ding 已提交
427
</details>
D
dingbo 已提交
428 429 430 431 432

</TabItem>
</Tabs>