资讯专栏INFORMATION COLUMN

【分布式NewSQL数据库 TiDB】性能数据,常见问题以及产品定价

Tecode / 2836人阅读

摘要:性能数据可以通过水平扩容的方式提升性能,以下为在固定配置下的数据表现。每个键值对不超过,键值对的总大小不超过。定价计费方式为用户提供服务,实行按小时计费方式。

性能数据

TiDB可以通过水平扩容的方式提升性能,以下为TiDB在固定配置下的数据表现。

测试环境

1 tidb版本: v3.0.5

2 tikv节点数: 3(单节点内存使用约30G)

3 线程: 512

4 表: 32 * 6000万条数据

5 数据量约1.3T

6 事务: 1000万

7 测试时间: 600(s)

8 sysbench: v1.0.13

跨可用区类型

操作DeleteInsertOltpSelectupdate index
read0029160418100000000
write53990588766893517695606271289
other46009420732036603728711
total100000008766893416577401000000010000000
transactions10000000 (22371.77 per sec.)8766893 (14610.32 per sec.)2082887 (3470.58 per sec.)10000000 (63480.92 per sec.)10000000 (18292.54 per sec.)
queries10000000 (22371.77 per sec.)8766893 (14610.32 per sec.)41657740 (69411.50 per sec.)10000000 (63480.92 per sec.)10000000 (18292.54 per sec.)
ignored errors0 (0.00 per sec.)0 (0.00 per sec.)0 (0.00 per sec.)0 (0.00 per sec.)0 (0.00 per sec.)
reconnects0 (0.00 per sec.)0 (0.00 per sec.)0 (0.00 per sec.)0 (0.00 per sec.)0 (0.00 per sec.)
total time446.9905s600.0467s600.1546s157.5262s546.6693s
total number of events10000000876689320828871000000010000000
延时latency min(ms)1.917.4954.980.611.92
延时latency avg(ms)22.8835.04147.508.0627.99
延时latency max(ms)5332.54285.324198.65239.999851.13
延时latency 95th percentile(ms)54.8356.84186.5421.1162.19
延时latency sum(ms)228819822.49307187149.43307227921.1580609016.31279850391.93
线程公平性(events (avg/stddev))19531.2500/746.2417122.8379/512.844068.1387/278.9380609016.3119531.2500/610.81
线程公平性 execution time (avg/stddev)446.9137/0.01599.9749/0.01600.0545/0.04157.4395/0.02546.5828/0.01

同可用区类型

操作DeleteInsertOltpSelectupdate index
read0035104384100000000
write496783610000000603993905715841
other50321640900479704284159
total1000000010000000501491201000000010000000
transactions10000000 (31633.96 per sec.)10000000 (19810.12 per sec.)2507456 (4178.42 per sec.)10000000 (72581.93 per sec.)10000000 (24383.18 per sec.)
queries10000000 (31633.96 per sec.)10000000 (19810.12 per sec.)50149120 (83568.32 per sec.)10000000 (72581.93 per sec.)10000000 (24383.18 per sec.)
ignored errors0 (0.00 per sec.)0 (0.00 per sec.)0 (0.00 per sec.)0 (0.00 per sec.)0 (0.00 per sec.)
reconnects0 (0.00 per sec.)0 (0.00 per sec.)0 (0.00 per sec.)0 (0.00 per sec.)0 (0.00 per sec.)
total time316.1144s504.7909s600.0958s137.7739s410.1173s
total number of events100000001000000025074561000000010000000
延时latency min(ms)0.541.8916.700.380.53
延时latency avg(ms)16.1825.84122.527.0520.99
延时latency max(ms)7359.571119.64687.53691.314990.75
延时latency 95th percentile(ms)51.9447.47193.3818.6162.19
延时latency sum(ms)161821250.26258417879.28307218046.8470500537.78209946556.81
线程公平性(events (avg/stddev))19531.2500/182.0919531.2500/151.344897.3750/116.0119531.2500/183.1919531.2500/178.73
线程公平性 execution time (avg/stddev)316.0571/0.01504.7224/0.01600.0352/0.03137.6964/0.02410.0519/0.01

FAQ

Q1:TiDB当前覆盖多少地域?

TiDB当前仅在北京二地域开放。有需要使用的用户请联系技术支持或者客户经理开放使用。

Q2:每个小时我们要创建一些中间表,完成计算,然后删除掉?频繁创建和删除表对TiDB 性能影响大吗?

从技术实现的角度,对影响并没有很大的影响,因为你每个小时操作的库都是不一样的,都是独立的数据, 但会影响gc,如果你们每个小时的数据量很大的话,会有一定的影响,数据量小可以忽略。其实就是频繁删 除数据,主要是这里影响,数据删除之后,在一定时间被gc,如果堆积的量大的话,会影响写入的性能.

Q3: slow log 里面的时间是什么时区?

admin show slow 是跟着服务所在宿主机的时区的,没法设置,建议使用select语句查询,select 会应用你设置的时区信息。

select * from information_schema.slow_query ;

admin show slow log top 4;

Q4: 对于一张大表insert into t2 select * from t1; 失败报错 ERROR 2013 (HY000): Lost connection to MySQL server during query

这种情况基本上是 Transaction too large

TiDB对事务有限制:

单个事务包含的 SQL 语句不超过 100000 条。每个键值对不超过 6MB,键值对的总大小不超过 100MB。

Q5: TiDB 是否支持 select for update?

支持,但语义上和 MySQL 有区别,TiDB 是分布式数据库,采用的乐观锁机制,也就说 select for update 不在事务开启就锁住数据,而是其他事务在提交的时候进行冲突检查,如有冲突,会进行回滚。

Q6: 事务太大(insert ... select),或者select..for update,以及网络问题,执行事务TiDB会返回错误,有什么办法可以区分吗?

可根据TiDB的 error codes 去判断

Q7: TIDB能否支持session级别的悲观锁

执行 set @@tidb_txn_mode = pessimistic;,使这个 session 执行的所有显式事务(即非 autocommit 的事务)都会进入悲观事务模式。

Q8:TiDB binlog的目标端在以下情况不支持udb-mysql5.6.41版本

udb-mysql5.6.41的索引键前缀默认限制为767字节,TiDB的表设计的key过长,全量同步时会报错。

如果一定要使用udb-mysql5.6版本,需如下操作:

1.目标端启用系统变量innodb_large_prefix

  1).系统变量innodb_large_prefix为ON

  2).系统变量innodb_file_format为Barracuda

如果用户权限不够,先调整自己的super权限:

mysql>update mysql.user set super_priv = Y where user = root;

mysql>flush privileges;

mysql>set global innodb_large_prefix=on;

mysql>set global innodb_file_format=Barracuda;

2.源端需要修改表属性:

mysql> ALTER TABLE TEST ROW_FORMAT=DYNAMIC;

目标端支持:udb-mysql 5.7

Q9:在 TiDB 中,表或字段设置为utf8 和 设置为 utf8mb4 的效果是否一样

v2.1.3及其后续版本,默认字符集由uft8改为utf8mb4,效果是一样的,但为了保证备份数据和binlog导出的数据能兼容其他数据库,需显式的指定为utf8mb4

Q10: TiDB 加个联合索引会锁表吗

首先,TiDB内部没有锁表的机制:https://pingcap.com/docs-cn/dev/reference/sql/statements/flush-tables/#mysql-%E5%85%BC%E5%AE%B9%E6%80%A7

其次,TiDB 中,ADD INDEX 为在线操作,不会阻塞表中的数据读写。https://pingcap.com/docs-cn/dev/reference/sql/statements/add-index/

但是, 如果在创建索引的时候,刚好跟要读写的数据 碰巧是同一部分数据,这个是会影响的,因为创建索引需要填充数据,也会涉及读写操作。

从历史版本读就不影响读取的速度。

Q11:TiDB默认时区

当前实例创建完成后,默认时区为UTC时间,如果用户需要CST时间,需要手动设置时区+8

set @@time_zone = +8:00;   SET GLOBAL time_zone =+8:00;

重新连接mysql即可生效

Q12:查看TiDB创建索引的过程是否已经结束

通过“admin show ddl;”语句查看当前job的进度

Q13:TiDB最大连接数

系统变量max_connections仅为兼容MySQL而设计,并无实际效果;

单TiDB实例(流量限制)当前支持最大3000个session(可扩容);

Q14: SQL执行时间突然变长

在执行SQL语句前,TiDB会通过统计信息计算出执行计划,选择全表扫还是从索引中获取数据,如果一张表数据量非常大,TiDB的选择算法误差比较大,一旦选择全表扫,会严重影响集群性能,建议强制使用索引

use index(index_name):https://book.tidb.io/session4/chapter6/sql-optimization-cases.html#%E6%A1%88%E4%BE%8B5-sql-%E6%89%A7%E8%A1%8C%E8%AE%A1%E5%88%92%E4%B8%8D%E5%87%86

Q15: 如何通过tableID 查找表名

INFORMATION_SCHEMA.TABLES 中有对应关系。

TiDB定价

1. 计费方式

UCloud TiDB Service 为用户提供serverless服务, 实行按小时计费方式。

2. 计费内容

TiDB 集群费用

具体收费内容如下:

| 类型 | 单价(元/小时/GB)| 组件|
| ------- | ------- | ------- |
| 硬盘(NVME) | 0.004 | TiKV Pump TiFlash |
| 内存 | 0.2 | TiKV Pump Drainer TiFlash |

备份数据存储费用

对于同可用区实例, 如果用户开启了备份功能,备份数据存储在用户的US3空间中,US3的费用由用户承担。

实时文档请前往https://docs.ucloud.cn/tidb/price

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/126182.html

相关文章

  • 布式NewSQL数据 TiDB产品简介

    摘要:什么是是公司研发的开源分布式关系型数据库。定位于在线事务处理在线分析处理的融合型数据库产品。基于的,实现在公有云的产品化,给用户提供无需关心底层资源池按需使用接入方便的高性能数据库服务。默认不做限制,按需使用。什么是TiDBTiDB 是 PingCAP 公司研发的开源分布式关系型数据库。定位于在线事务处理、在线分析处理 HTAP 的融合型数据库产品。兼容 MySQL 协议,支持水平伸缩,具备...

    Tecode 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<