分享3个Sysbench性能压测脚本及多并发压测过程
sinye56 2024-10-04 23:43 7 浏览 0 评论
概述
sysbench是基于LuaJIT的可以脚本化多线程基准。 它是一个模块化的、跨平台、多线程基准测试工具,最常用于数据库基准测试,但也可以用于创建不涉及数据库服务器的任意复杂工作负载。
目前sysbench主要支持 MySQL,pgsql,oracle 这3种数据库。
今天主要分享一下sysbench常用的一些脚本以及sysbench压测。
一、压测环境
生产环境:
MySQL服务器IP地址:xx.xx.xx.xx
操作系统:CentOS Linux release 7.3.1611 (Core)
CPU:4核
内存:8G
硬盘:普通SAS硬盘
基线测试工具:sysbench
二、相关脚本
1、采集tps的脚本(analyze_tps.sh)
#!/bin/bash cat $1|awk '/10s ]/,/1800s ]/{print $0}'|awk -F '[' '{print $2}'|awk -F ']' '{print $1,$2}'|awk '{print $1,$5}'|awk -F ',' '{print $1}'|awk -F 's' '{print $1 $2}' > $2
脚本的'/10s]/,/1800s] 这2个参数是需要根据实际情况进行更改的,我sysbench采取的是10s计数一次,累计运行1800s,所以统计是从10s开始直到1800s结束;
其中tps的值在过滤之后位于$5的位置,可以直接取出
2、采集qps的脚本(analyze_qps.sh)
#!/bin/bash cat $1|awk '/10s ]/,/1800s ]/{print $0}'|awk -F '[' '{print $2}'|awk -F ']' '{print $1,$2}'|awk '{print $1,$7+$9}'|awk -F ',' '{print $1}'|awk -F 's' '{print $1 $2}' > $2
3、绘图脚本(sysbench-graph.sh)
#!/bin/bash gnuplot << EOP set style line 1 lt 1 lw 3 set style line 2 lt 2 lw 3 set style line 3 lt 3 lw 3 set style line 4 lt 4 lw 3 set style line 5 lt 5 lw 3 set style line 6 lt 6 lw 3 set style line 7 lt 7 lw 3 set terminal png size 960,480 set grid x y set xlabel "Time(sec)" set ylabel "TPS" set output "$2" plot "$1" using 1:2 title "threads=2" ls 1 with lines,\ "$1" using 3:4 title "threads=100" ls 2 with lines,\ "$1" using 5:6 title "threads=200" ls 3 with lines,\ "$1" using 7:8 title "threads=300" ls 4 with lines,\ "$1" using 9:10 title "threads=500" ls 5 with lines,\ "$1" using 11:12 title "threads=800" ls 6 with lines axes x1y1 EOP
三、sysbench压测预演
1、到被测试的库里建库,建用户,授权
set global validate_password_policy=0; ##因为lua脚本里面这里设置的就是sbtest库,库名需要与脚本里的内容保持一致 create database sbtest; grant all privileges on sbtest.* to tpcc@'%' identified by 'tpcc@1234'; flush privileges;
2、会产生报错的操作(将oltp.lua中的mysiam修改成innodb后,会找不到表)--不执行
cd /usr/local/sysbench/share/sysbench/tests/include/oltp_legacy cp oltp.lua oltp_innodb.lua sed -i 's/myisam/innodb/g' /usr/local/sysbench/share/sysbench/tests/include/oltp_legacy/oltp_innodb.lua
3、测试多表的压测
###################################执行prepare########################################## --test=/usr/local/sysbench/share/sysbench/tests/include/oltp_legacy/oltp.lua //表示调用oltp.lua 脚本进行 oltp 模式测试 --oltp_tables_count=20 //20张表 --oltp-table-size=1000000 //每张表100万数据 ####################################################################################### sysbench --mysql-host=172.26.151.69 --mysql-port=3306 --mysql-user=tpcc --mysql-password=tpcc@1234 \ --test=/usr/local/sysbench/share/sysbench/tests/include/oltp_legacy/oltp.lua --oltp_tables_count=20 \ --oltp-table-size=1000000 --rand-init=on prepare ###################################执行run############################################### --num-threads=4 //4个并发连接 --max-time=30 //测试时间为30s --report-interval=5 //报告打印周期为5s --oltp-read-only=off //非只读操作测试 --max-requests=0 //最大执行次数这里不做限制,只由max-time进行限制 ######################################################################################### sysbench --mysql-host=172.26.151.69 --mysql-port=3306 --mysql-user=tpcc --mysql-password=tpcc@1234 \ --test=/usr/local/sysbench/share/sysbench/tests/include/oltp_legacy/oltp.lua --oltp_tables_count=20 \ --oltp-table-size=1000000 --num-threads=4 --oltp-read-only=off --report-interval=5 --rand-type=uniform \ --max-time=30 --max-requests=0 --percentile=99 run ###################################执行清除################################################## ★重点关注:总的事务数,每秒事务数TPS,QPS,时间统计信息(最大、最小、平均、99%以上语句响应时间)★ ############################################################################################ sysbench --mysql-host=172.26.151.69 --mysql-port=3306 --mysql-user=tpcc --mysql-password=tpcc@1234 \ --mysql-db=sbtest --oltp-tables-count=20 --oltp-table-size=1000000 --num-threads=16 --max-requests=0 \ --max-time=30 --report-interval=1 --test=/usr/local/sysbench/share/sysbench/tests/include/oltp_legacy/oltp.lua cleanup
说明:
read: 154280 //读总数,select语句
write: 44080 //写总数,insert、delete、update语句
other: 22040 //其它语句,如commit等
total: 220400 //总的执行语句数
transactions: 11020 (367.14 per sec.) //总的事务数(★每秒处理事物数:TPS★)
queries:: 220400 (7342.85 per sec.) //读写请求次数(★每秒的读写次数:QPS★)
total time: 30.0133s //总时间
total number of events: 11020 //★事务总数★
min: 6.97ms //最小延迟时间
avg: 10.89ms //平均延迟时间
max: 48.47ms //最大延迟时间
99th percentile:: 21.89ms //99%语句执行时间
Threads fairness: //线程公平性
events (avg/stddev): 2755.0000/91.59 //平均每个线程完成envet的次数,后一个值是标准差
execution time (avg/stddev): 29.9929/0.00 //平均每个线程平均耗时,后一个值是标准差
上面三个脚本后面有大用,建议大家收藏一下。觉得有用的朋友多帮忙转发哦!后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注下~
相关推荐
- Linux中10大常用命令之sort使用案例
-
请关注本头条号,每天坚持更新原创干货技术文章。如需学习视频,请在微信搜索公众号“智传网优”直接开始自助视频学习1.前言Linux中的sort命令用于对文本文件的内容进行排序。本教程向您展示了sort...
- java开发常用的Linux命令,高频的没你想象的多
-
Linux的命令非常多,多到有些使用的场景你工作两三年也没有遇到过,工作三四年才能遇到(Linux内核开发,Shell脚本开发,嵌入式开发、、、),但这个不是今天分享的重点,今天分享的重点是Java开...
- linux常用命令(收藏版)
-
linux小白注意啦,给大家分享一点干货,请笑纳!1.关机命令shutdown-hnow关闭系统(1)init0关闭系统(2),0为系统的进程号telinit0关闭系统(3)shutdo...
- 延续Win10三年需付超3000元!微软彻底封堵:删除绕过Win11系统要求教程、将第三方工具标记为恶意软件
-
一切都是为了用户能够正规地升级到Windows11。整理|屠敏出品|CSDN(ID:CSDNnews)距离Windows10退役仅剩8个月,微软最近这段时间,终是忍不住接连出手了...
- 敲完就让你提桶跑路的Linux命令
-
不谨慎可能就会让你提桶的Linux命令!!!删除文件rm-rf该命令是删除文件或文件夹等最快的方式之一。删除后的内容很难恢复,如果删除系统文件可能会导致系统崩坏。˃rm-rf/#强制删除根...
- 超级蠕虫,累计感染40万台服务器,让Linux内核服务器感染两年
-
最近著名安全公司ESET发布安全报告,报告分析了其对一个超级蠕虫Ebury的15年追踪分析。在15年中该病毒持续感染了40万台服务器,曾经在2011年(2009年)攻克了Linux内核维护站点kern...
- linux redhat破解密码
-
适用于RedhatCentosFedora1.开机选择第一个启动项,按e进入编辑模式2.在启动项编辑模式找到linux16开头的文件,按ctrl+e快速定位到该行的行末,输入空格rd.break...
- 慎用!Linux最危险的10个命令!
-
Linux是一个强大而灵活的操作系统,它提供了许多功能丰富的命令和工具,让用户可以方便地管理和控制系统。但是,有些命令如果不小心或不知情地使用,可能会造成严重的后果,甚至导致系统崩溃或数据丢失。因此,...
- Linux文件和目录删除
-
今天只讲一个命令,这个命令已经让万千运维人既爱又恨。rm删除文件或者目录基本用法:-i显示删除提示信息-f强制删除文件-r进行目录的递归删除在公司里为了保证数据安全,一般会创建一个alias...
- 给你的Linux系统穿上“防弹衣”:安全加固全攻略
-
为什么Linux系统需要安全加固在当今数字化时代,Linux系统以其开源、稳定、高效等特性,在服务器领域占据着举足轻重的地位。无论是大型互联网公司的核心业务,还是中小企业的日常运营,都离不开L...
- 一天一个Linux命令:文件操作「删」rm
-
命令:rm-rf文件名(慎用,慎用,慎用)rm(选项)(参数)命令功能:rm-rf是一条UNIX系统下的文件删除命令,作用是无提示地强制递归删除一个目录中的一个或多个文件或目录,如果没有使用...
- Linux下通过 rm -f 删除大量文件时报错:Argument list too long
-
问题现象云服务器ECSLinux下通过rm-f删除大量的小文件时出现类似如下错误信息:-bash:?/bin/rm:?Argument?list?too?long如下图所示:问题原因如?待删...
- 这10个Linux命令太危险,千万慎用!数据毁灭的瞬间只需一个回车
-
你好,这里是网络技术联盟站,我是瑞哥。Linux系统,以其开源自由的特性,吸引了无数开发者和科技爱好者。其强大的命令行工具赋予了用户前所未有的控制能力。然而,正如俗话所说,“能力越大,责任越大”。某些...
- Linux的10大危险命令,用过的运维都很刑
-
rm-rf命令该命令可能导致不可恢复的系统崩坏。˃rm-rf/#强制删除根目录下所有东西。˃rm-rf*#强制删除当前目录的所有文件。˃rm-rf.#强制删除当前...
- Linux环境变量设置与查看全攻略
-
Linux环境变量设置与查看全攻略在Linux系统中,环境变量是用于定义系统和用户级设置的一种方法,它可以影响程序的行为和系统的运行方式。了解如何设置和查看环境变量对于Linux用户来说是非常重要的技...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle忘记用户名密码 (59)
- oracle11gr2安装教程 (55)
- mybatis调用oracle存储过程 (67)
- oracle spool的用法 (57)
- oracle asm 磁盘管理 (67)
- 前端 设计模式 (64)
- 前端面试vue (56)
- linux格式化 (55)
- linux图形界面 (62)
- linux文件压缩 (75)
- Linux设置权限 (53)
- linux服务器配置 (62)
- mysql安装linux (71)
- linux启动命令 (59)
- 查看linux磁盘 (72)
- linux用户组 (74)
- linux多线程 (70)
- linux设备驱动 (53)
- linux自启动 (59)
- linux网络命令 (55)
- linux传文件 (60)
- linux打包文件 (58)
- linux查看数据库 (61)
- linux获取ip (64)
- linux进程通信 (63)