TiDB升级、TiFlash测试及对比ClickHouse
--2020-05-13 刘春雷
测试3.0.7 升级至4.0.0-rc
测试部署TiFlash
测试TiFlash性能等
对比ClickHouse
序列 | SQL | 表改成TiFlash命令 | tikv时间 | TiFlash时间 | ClickHouse | 百分比 |
12 |
举例模拟: CREATE TABLE `test` ( 表数据: 8324 w SQL: select avg(num) from test where create_time >'2020-05-07 17:40:01'; |
alter table test SET TIFLASH REPLICA 1; | 1 row in set ( 5.19sec) | 1 row in set ( 0.80 sec) |
1 row in set 0.041 sec |
TiFlash比TiKV减少: 84.6% ClickHouse比TiFlash减少: 74.9% |
1、升级至4.0.0-rc
2、部署TiFlash
3、添加表至tiflash
4、会话级别设置使用tikv及tiflash
5、测试查询
集群:xxx集群
TiDB&PD 混合部署
TiKV*3
TiFlash *1
角色 |
机器 |
TiFlash/TiKV/ClickHouse |
内存:192G CPU:20*2 Intel(R) Xeon(R) Silver 4114 CPU @ 2.20GHz 磁盘:3*1.8T SSD |
ClickHouse:为单机部署
TiDB3.0.7集群部署完成
【1】、打包4.0.0-rc版本 完成
【2】、执行升级 完成
注:自己开发的工具
tidb_manage --options=upgrade -c xxx -o 3.0.7 -n 4.0.0-rc
在 pd-ctl,开启 PD 的 Placement Rules 功能。
cd tidb-ansible-4.0.0-rc-xxx/resources/bin
./pd-ctl -u "http:10.xxx.x.x:xxx" -i
config set enable-placement-rules true
ssh tidb中控
su - tidb
cd tidb-4.0.0-rc-xxx
【1、配置】
配置 scale-out.yaml
【2、执行扩容】
tiup cluster scale-out TiflashTest scale-out.yaml
Scaled cluster `TiflashTest` out successfully
序列 | SQL | 表改成TiFlash命令 | tikv时间 | TiFlash时间 | 百分比 |
12 |
举例模拟: CREATE TABLE `test` ( 表数据: 8324 w SQL: select avg(num) from test where create_time >'2020-05-07 17:40:01'; |
alter table test SET TIFLASH REPLICA 1; | 1 row in set ( 5.19 sec) | 1 row in set ( 0.80 sec) | 减少84.6% |
结果:
ClickHouse比TiFlash减少: 74.9%
SQL:
create database test;
CREATE TABLE test ENGINE = MergeTree order by id AS SELECT * FROM mysql('IP:port', 'db', 'test', 'user', 'password');
【差异原因】:
tiflash 因为需要支持 update,所以需要额外读取三列:handle (int64), version(uint64), del_mark(uint8)
clickHouse 只需要 scan,但是 tiflash 需要把数据做一次全局排序 + mvcc 过滤,这些是固定成本。
【1、添加表至TiFlash】
alter table xxx SET TIFLASH REPLICA 1;
【2、查看进度,需要available=1 后才可能使用到tiflash】
SELECT * FROM information_schema.tiflash_replica ;
【3、设置引擎,会话级别】
set SESSION tidb_isolation_read_engines = "tikv";
set SESSION tidb_isolation_read_engines = "tikv,tiflash";
set SESSION tidb_isolation_read_engines = "tiflash";
【4、执行具体SQL或执行计划】
查看执行计划,如果有cop[tiflash],则说明使用到了tiflash
【5、其他优化参数,会话级,待确认优化程度】
set @@tidb_opt_agg_push_down=1;
set @@tidb_opt_distinct_agg_push_down=1;