MySQL压力测试最佳实践(16/16)

MySQL压力测试

基本概述

sysbench是一个模块化的、跨平台、多线程基准测试工具,主要用于评估测试各种不同系统参数下的数据库负载情况。项目地址:http://github.com/akopytov/sysbench

工具安装

1.1 在线安装(CentOS):

curl -s https://packagecloud.io/install/repositories/akopytov/sysbench/script.rpm.sh | sudo bash
sudo yum -y install sysbench

安装报错缺少libmysqlclient.so.18(libmysqlclient_18)(64bit)依赖时,需要下载rpm包进行安装:

# CentOS 7
wget http://downloads.mysql.com/archives/get/p/23/file/mysql-community-libs-compat-5.7.22-1.el7.x86_64.rpm

rpm -ivh mysql-community-libs-compat-5.7.22-1.el7.x86_64.rpm

其它版本,请到官网自行下载:http://downloads.mysql.com/

其它系统安装方法请见github:https://github.com/akopytov/sysbench

1.2 离线安装(CentOS)

下载安装包后解压,添加相关依赖后进行编译。

unzip sysbench-xxxx.zip

yum install m4 autoconf automake libtool
yum -y install mysql-devel(mysql数据库依赖库,其他数据库要换成对应的xxx-devel)

# 自动生成脚本
./autogen.sh

# 编译安装
./configure
make && make install

# 检验是否安装成功
cd /usr/bin/
./sysbench --version
压力测试
  1. 提前在数据库上创建好sbtest数据库。

  1. 创建一张500w的记录表。
sysbench /usr/share/sysbench/tests/include/oltp_legacy/oltp.lua \
--mysql-host=node02 \
--mysql-port=3306 \
--mysql-user=root  \
--mysql-password='DBa2020*' \
--mysql-db=sbtest \
--oltp-test-mode=complex \
--oltp-tables-count=1 \
--oltp-table-size=5000000 \
--threads=128  \
--oltp-nontrx-mode=select \
--oltp-read-only=off \
--max-time=120 \
--report-interval=10 \
prepare

  • 这里使用的是oltp.lua脚本,里面测试内容大概是线程和建表、查询、更改、删表的操作。sysbench还包含其它功能脚本,默认安装后处于/usr/share/sysbench/tests/include/oltp_legacy/目录下。
1. bulk_insert.lua  批量写入操作
2. oltp_delete.lua 写入和删除并行操作
3. oltp_insert.lua  纯写入操作
4. oltp_point_select.lua  只读操作,条件为唯一索引列
5. oltp_read_only.lua  只读操作,包含聚合,去重等操作
6. oltp_read_write.lua 读写混合操作,最常用的脚本
7. oltp_update_index.lua 更新操作,通过主键进行更新
8. oltp_update_non_index.lua 更新操作,不通过索引列
9. oltp_write_only.lua 纯写操作,常用脚本,包括insert update delete
10. select_random_points.lua 随机集合只读操作,常用脚本,聚集索引列的selete in操作
11. select_random_ranges.lua 随机范围只读操作,常用脚本,聚集索引列的selete between操作

-- 内容引用自博客 https://blog.51cto.com/u_13874232/5582905
  • 其它常用参数。
Sysbench中常用的参数如下:

--mysql-table-engine=innodb 表示选择测试表的存储引擎
--oltp_tables_count=10 表示会生成 10 个测试表
--oltp-table-size=100000 表示每个测试表填充数据量为 100000
--rand-init=on 表示每个测试表都是用随机数据来填充的
如果在本机,也可以使用 –mysql-socket 指定 socket 文件来连接。加载测试数据时长视数据量而定,若过程比较久需要稍加耐心等待。

--oltp-read-only=off 表示不要进行只读测试,也就是会采用读写混合模式测试
--report-interval=10 表示每10秒输出一次测试进度报告
--rand-type=uniform 表示随机类型为固定模式,其他几个可选随机模式:uniform(固定),gaussian(高斯),special(特定的),pareto(帕累托)
--max-time=120 表示最大执行时长为 120秒
--max-requests=0 表示总请求数为 0,因为上面已经定义了总执行时长,所以总请求数可以设定为 0;也可以只设定总请求数,不设定最大执行时长
--percentile=99 表示设定采样比例,默认是 95%,即丢弃1%的长请求,在剩余的99%里取最大值
--num-threads=12: 并发线程数,可以理解为模拟的客户端并发连接数

--mysql-db=sbtest:测试使用的目标数据库,这个库名要事先创建
--oltp-tables-count=10:产生表的数量
--oltp-table-size=500000:每个表产生的记录行数
--oltp-dist-type=uniform:指定随机取样类型,可选值有 uniform(均匀分布), Gaussian(高斯分布), special(空间分布)。默认是special
--oltp-read-only=off:表示不止产生只读SQL,也就是使用oltp.lua时会采用读写混合模式。默认 off,如果设置为on,则不会产生update,delete,insert的sql。
--oltp-test-mode=nontrx:执行模式,这里是非事务式的。可选值有simple,complex,nontrx。默认是complex
simple:简单查询,SELECT c FROM sbtest WHERE id=N
complex (advanced transactional):事务模式在开始和结束事务之前加上begin和commit, 一个事务里可以有多个语句,如点查询、范围查询、排序查询、更新、删除、插入等,并且为了不破坏测试表的数据,该模式下一条记录删除后会
在同一个事务里添加一条相同的记录。
nontrx (non-transactional):与simple相似,但是可以进行update/insert等操作,所以如果做连续的对比压测,你可能需要重新cleanup,prepare。
--oltp-skip-trx=[on|off]:省略begin/commit语句。默认是off
--oltp_secondary=on:将ID设置为非主键防止主键冲突。
--oltp_range_size=5: 连续取值5个,必定走到5个分片。
--mysql_table_options='dbpartition by hash(id) tbpartition by hash(id) tbpartitions 2':PolarDB-X 1.0支持拆分表,在建表的时候需要指定拆分方式。

-- 内容引用自博客 https://blog.51cto.com/u_13874232/5582905
  1. 使用4线程(–num-threads=4)进行压力测试,测试60s(–max-time=60),每隔10s(–report-interval=10)输出一次测试信息。
sysbench --mysql-host=node02 \
--mysql-port=3306 \
--mysql-user=root \
--mysql-password=DBa2020* \
--test=/usr/share/sysbench/tests/include/oltp_legacy/oltp.lua \
--oltp_tables_count=1 \
--oltp-table-size=1000000 \
--num-threads=4 \
--oltp-read-only=off \
--report-interval=10 \
--rand-type=uniform \
--max-time=60 \
--max-requests=0 \
run

  1. 测试结果会输出在控制台上,主要关注以下参数。
transactions:                        2428   (39.27 per sec.)
    read/write requests:                 43704  (706.81 per sec.)
    other operations:                    4856   (78.53 per sec.)

作者与版本更新计划

感谢您的阅读与支持!本文是《MySQL实战与优化》专栏中的一篇精选文章,该专栏共包含16篇文章,旨在为您提供实战中可直接应用的宝贵知识。

关注公众号【数舟】,获取作者最新动态,公众号后台回复【mysql2024】,即可免费领取这份包含16篇文章的完整的PDF专栏!

目前版本为v1.0,更新时间2024年4月10日。后续此文档更新与版本发布会同步到知识星球【数舟】中。

知识整理与创作不易,感谢大家理解与支持!

加入知识星球,您将获得更多独家内容、专栏更新以及与行业内专家和同行的互动交流机会。我们在知识星球等您,一起探索MySQL的深层次世界!

星球内目前包含300+精品文章,内容涵盖大数据、MySQL、运维、Python、调优、经验分享、数据分析等方向内容,会根据大家的学习需求更新更多方向的内容。

🔗 立即扫描下方二维码,加入知识星球,与行业精英共同成长,开启您的专属学习之旅!

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

桥路丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值