06 生产经验:互联网公司的生产环境数据库是如何进行性能测试的?
作者:
呢看了看 | 来源:发表于
2020-12-01 17:30 被阅读0次QPS:Query Per Second。QPS就是说,你的这个数据库每秒可以处理多少个请求。
TPS:Transaction Per Second。TPS就是说,每秒可以处理的事务量。就是说数据库每秒会处理多少次事务提交或者回滚。简单来说,一个事务就会包含多个SQL语句,这些SQL最好要么就是事务提交,大家一起成功了,要么就是最好事务回滚,大家一起失败了,这就是事务。
TPS往往指的是一个数据库每秒里有多少个事务执行完毕了,事务提交或者事务回滚都算是执行完毕了 ,所以TPS衡量的是一个数据库每秒处理完的事务的数量。
IO相关的压测性能指标
【1】IQPS:这个指的是机器的随机IO并发处理的能力,比如机器可以达到200IQPS,意思就是说每秒可以执行200个随机IO读写请求。这个指标是很关键的,你在内存中更新的脏数据库,最后都是由后台IO线程在不确定的时间,刷回到磁盘里去,这就是随机IO的过程。如果说IQPS指标太低了,那么会导致你内存里的脏数据刷回磁盘的效率就会不高。
【2】吞吐量:这个指的是机器的磁盘存储每秒可以读写多少字节的数据量。这个指标是很关键的,我们在执行各种SQL语句的时候,提交事务的时候,其实都是大量的会写redo log之类的日志的,这些日志都会直接写磁盘文件。所以一台机器他的存储每秒可以读写多少字节的数据量,就决定了他每秒可以把多少redo log之类的日志写入到磁盘文件里去,一般来说我们写redo log之类的日志,都是对磁盘文件进行顺序写入的,也就是一行接着一行的写,不会说进行随机的读写,那么一般普通磁盘的顺序写入的吞吐量每秒都可以达到200MB左右。所以通常而言,机器的磁盘吞吐量都是足够承载高并发请求的。
【3】latency:这个指标说的是往磁盘里写入一条数据的延迟。我们执行SQL语句和提交事务的时候,都需要顺序写redo log磁盘文件,所以此时你写一条日志到磁盘文件里去,到底是延迟1ms,还是延迟100us,这就对你的数据库的SQL语句执行性能是有影响的。一般来说,当然是你的磁盘读写延迟越低,那么你的数据库性能就越高,你执行每个SQL语句和事务的时候速度就会越快。
【4】CPU负载:CPU负载是一个很重要的性能指标,因为假设你数据库压测到了每秒处理3000个请求了,可能其他的性能指标都还正常 ,但是此时CPU负载特别高,那么也说明你的数据库不能继续往下压测更高的QPS了,否则CPU是吃不消的。
【5】网络负载:这个主要是看看你的机器宽带的情况下,在压测到一定的QPS和TPS的时候,每秒钟机器的网卡会输入多少MB数据,会输出多少MB数据,因为有可能你的网络宽带最多每秒传输100MB的数据,那么可能你的QPS到1000的时候,网卡就打满了,已经每秒传输100MB的数据了,此时即使其他指标都还算正常,但是你也不能继续压测了。
【6】内存负载:这个就是看看在压测到一定情况下的时候,你的机器内存耗费了多少,如果说机器内存耗费过高了,说明也不能继续压测下去了。
本文标题:06 生产经验:互联网公司的生产环境数据库是如何进行性能测试的?
本文链接:https://www.haomeiwen.com/subject/bmmvxktx.html
网友评论