Linux性能优化(二)——sysbench压力测试工具

article/2025/9/27 13:23:38

一、sysbench简介

1、sysbench简介

sysBench是一个模块化的、跨平台、多线程基准测试工具,主要用于评估测试各种不同系统参数下的数据库负载情况。sysbench提供如下测试:

(1)CPU性能
(2)磁盘IO性能
(3)调度程序性能
(4)内存分配及传输速度 
(5)POSIX线程性能
(6)数据库性能(OLTP基准测试)      

sysbench支持 MySQL、PostgreSQL、Oracle 数据库。

2、sysbench安装

Build构建依赖安装:

yum -y install make automake libtool pkgconfig libaio-develyum -y install mariadb-devel openssl-develyum -y install postgresql-devel

源码下载:

git clone https://github.com/akopytov/sysbench.git

生成配置工具:

autogen.sh

配置选项:

--with-pgsql:支持PostgreSQL--with-oracle:支持Oracle--without-mysql:无MySQL支持configure [options]

编译:

make -j

安装:

make install

3、sysbench命令

sysbench [options]... [testname] [command]

testname是sysbench要执行的测试类型,可选项包括fileio、cpu、memory、threads、mutex,可以使用--test参数指定。

command是sysbench要执行的命令,包括prepare、run、cleanup,prepare为测试准备数据,run执行正式测试,cleanup在测试完成后对数据库进行清理。

sysbench通用参数选项如下:

--threads: 线程数,若设置为2,则sysbench会启动2个线程,同时分别进行素数的计算,默认值为1。

--time: 运行时长,单位秒。若设置为5,则sysbench会在5秒内循环进行素数计算,每完成一轮就是一个event,默认值为10。

--events: event上限次数,若设置为100,则表示当完成100次event后,即使时间富余也停止运行。默认值为0,则表示不限event次数。

--forced-shutdown=STRING:超时强制中断,默认为off。     --thread-stack-size=SIZE:线程栈大小,默认64K

--thread-init-timeout=N:线程初始化等待时间,默认为30秒

--rate=N:平均事务率,0表示不限制,默认为0。              

--report-interval=N:测试进度报告输出的时间间隔,0表示关闭,默认为0。

--report-checkpoints=[LIST,...]:转储完全统计信息并在指定时间点复位所有计数器,参数是逗号分隔值的列表,表示从必须执行报告检查点的测试开始所经过的时间(以秒为单位)。 默认情况下,报告检查点处于关闭状态[off]。

--debug[=on|off]:打印调试信息,默认为off

--validate[=on|off]:尽可能执行验证检查,默认为off。        

--help[=on|off]:打印help信息并退出,默认为off             

--version[=on|off]:打印版本信息并退出,默认为off           

--config-file=FILENAME:命令行选项文件

--luajit-cmd=STRING:执行LuaJIT控制命令

二、CPU性能基准测试

1、命令选项

sysbench --test=cpu help

--cpu-max-prime:素数生成数量的上限,若设置为3,则表示2、3、5(要计算1-5共5次),默认值为10000。

2、CPU性能测试

sysbench cpu --cpu-max-prime=20000 --threads=8 --time=30 run

Prime numbers limit: 20000,每个线程产生的素数上限均为2000

events per second: 650.7,所有线程每秒完成了650.74次event

total time: 10.0017s,共耗时10秒

total number of events: 6510,10秒内所有线程一共完成了6510次event

min: 3.03,完成1次event的最少耗时3.03秒

avg: 3.07,所有event的平均耗时3.07毫秒

max: 3.27,完成1次event的最多耗时3.27毫秒

95th percentile: 3.13, 95%次event在3.13秒毫秒内完成

sum: 19999.91,每个线程耗时10秒,2个线程叠加耗时就是20秒

events (avg/stddev): 3255.0000/44.00 // 平均每个线程完成3255次event,标准差为44

execution time (avg/stddev): 10.0000/0.00 // 每个线程平均耗时10秒,标准差为0

三、内存负载测试

 1、命令选项

sysbench  --test=memory help

--memory-block-size=SIZE:测试内存块的大小,默认为1K。

--memory-total-size=SIZE:数据传输的总大小,默认为100G。

--memory-scope=STRING:内存访问的范围,包括全局和本地范围,默认为global。

--memory-hugetlb=[on|off]:是否从HugeTLB池分配内存的开关,默认为off。

--memory-oper=STRING:内存操作的类型,包括read, write, none,默认为write

--memory-access-mode=STRING:内存访问模式,包括seq,rnd两种模式,默认为seq。

2、内存负载测试

sysbench memory --threads=12 --memory-block-size=8K --memory-total-size=100G --memory-access-mode=seq run

开启12个线程,内存块大小为8K,顺序读写

sysbench memory --threads=12 --memory-block-size=8K --memory-total-size=100G --memory-access-mode=rnd run

四、磁盘IO性能基准测试

1、命令选项

sysbench --test=fileio help

--file-num=N:生成测试文件的数量,默认为128。

--file-block-size=N:测试时所使用文件块的大小,如果想磁盘针对innodb存储引擎进行测试,可以将其设置为16384(innodb存储引擎页的大小),默认为16384。

--file-total-size=SIZE:创建测试文件的总大小,默认为2G大小。

--file-test-mode=STRING:文件测试模式,seqwr(顺序写)、seqrewr(顺序读写)、seqrd(顺序读)、rndrd(随机读)、rndwr(随机写)、rndrw(随机读写)。

--file-io-mode=STRING:文件操作模式,sync(同步)、async(异步)、fastmmap(快速mmap)、slowmmap(慢速mmap),默认为sync。

--file-async-backlog=N:对应每个线程队列的异步操作数,默认为128。

--file-extra-flags=STRING:打开文件时的选项,与API相关的参数。

--file-fsync-freq=N:执行fsync函数的频率。fsync主要是同步磁盘文件,0代表不使用fsync函数,默认值为100。

--file-fsync-all=[on|off]:每执行完一次写操作,就执行一次fsync。默认为off。

--file-fsync-end=[on|off]:测试结束时执行fsync函数,默认为on。

--file-fsync-mode=STRING:文件同步函数选择,和API相关的参数,由于多个操作系统对于fdatasync支持不同,因此不建议使用fdatasync,默认为fsync。

--file-merged-requests=N:大多情况下,合并可能的IO的请求数,默认为0。

--file-rw-ratio=N:测试时的读写比例,默认时为1.5,即可3:2。

2、数据准备

sysbench fileio --file-num=16 --file-total-size=2G prepare

3、执行测试

sysbench fileio --file-total-size=2G --file-test-mode=rndrd --time=180  --threads=16  --file-num=16 --file-extra-flags=direct --file-fsync-freq=0 --file-block-size=16384 run

4、清理数据

sysbench fileio --file-num=16 --file-total-size=2G cleanup

清理测试数据

五、多线程调度基准测试

1、命令选项

sysbench  --test=mutex help 

--mutex-num=N:数组互斥的总大小,默认为4096。

--mutex-locks=N:每个线程互斥锁的数量,默认为50000。

--mutex-loops=N:内部互斥锁的空循环数量,默认为10000。

2、多线程调度测试

sysbench mutex --threads=8 --mutex-num=2000 --mutex-locks=10000 --mutex-loops=5000 run

六、POST多线程基准测试

 1、命令选项

sysbench  --test=threads help

--thread-yields=N:指定每个请求的压力,默认为1000

--thread-locks=N:指定每个线程的锁数量,默认为8

2、多线程测试

sysbench threads --threads=8 --thread-yields=100 --thread-locks=2 run

七、OLTP基准测试

1、命令选项

sysbench --test=oltp help

--oltp-test-mode=STRING:测试模式,simple、complex、nontrx、sp,默认为complex。

--oltp-reconnect-mode=STRING:重连接模式,session不使用重连接,transaction在每次事务结束后重连接,query在每个SQL语句执行完重连接,random对于每个事务随机选择重连接模式,默认为session。

--oltp-sp-name=STRING:存储过程名称,默认为空

--oltp-read-only=[on|off]:只读模式。Update、delete、insert语句不可执行,默认为off

--oltp-skip-trx=[on|off]:省略begin/commit语句,默认为off。

--oltp-range-size=N:查询范围,默认为100。--oltp-point-selects=N:number of point selects [10]

--oltp-simple-ranges=N          number of simple ranges [1]

--oltp-sum-ranges=N             number of sum ranges [1]

--oltp-order-ranges=N           number of ordered ranges [1]

--oltp-distinct-ranges=N        number of distinct ranges [1]

--oltp-index-updates=N          number of index update [1]

--oltp-non-index-updates=N      number of non-index updates [1]

--oltp-nontrx-mode=STRING   查询类型对于非事务执行模式{select, update_key, update_nokey, insert, delete} [select]

--oltp-auto-inc=[on|off]      AUTO_INCREMENT是否开启。默认是on

--oltp-connect-delay=N     在多少微秒后连接数据库。默认是10000

--oltp-user-delay-min=N    每个请求最短等待时间。单位是ms。默认是0

--oltp-user-delay-max=N    每个请求最长等待时间。单位是ms。默认是0

--oltp-table-name=STRING  测试时使用到的表名。默认是sbtest

--oltp-table-size=N         测试表的记录数。默认是10000

--oltp-dist-type=STRING    分布的随机数{uniform(均匀分布),Gaussian(高斯分布),special(空间分布)}。默认是special

--oltp-dist-iter=N    产生数的迭代次数。默认是12

--oltp-dist-pct=N    值的百分比被视为'special' (for special distribution)。默认是1

--oltp-dist-res=N    ‘special’的百分比值。默认是75

2、Lua脚本

/usr/share/sysbench/bulk_insert.lua/usr/share/sysbench/oltp_common.lua/usr/share/sysbench/oltp_delete.lua/usr/share/sysbench/oltp_insert.lua/usr/share/sysbench/oltp_point_select.lua/usr/share/sysbench/oltp_read_only.lua/usr/share/sysbench/oltp_read_write.lua/usr/share/sysbench/oltp_update_index.lua/usr/share/sysbench/oltp_update_non_index.lua/usr/share/sysbench/oltp_write_only.lua/usr/share/sysbench/select_random_points.lua/usr/share/sysbench/select_random_ranges.lua

3、准备数据

sysbench ./tests/include/oltp_legacy/oltp.lua --mysql-host=192.168.10.10 --mysql-port=3306 --mysql-user=root --mysql-password=123456 --oltp-test-mode=complex --oltp-tables-count=10 --oltp-table-size=100000 --threads=10 --time=120 --report-interval=10 prepare

执行模式为complex,使用了10个表,每个表有10万条数据,客户端的并发线程数为10,执行时间为120秒,每10秒生成一次报告。

4、执行测试

sysbench ./tests/include/oltp_legacy/oltp.lua --mysql-host=192.168.10.10 --mysql-port=3306 --mysql-user=root --mysql-password=123456 --oltp-test-mode=complex --oltp-tables-count=10 --oltp-table-size=100000 --threads=10 --time=120 --report-interval=10 run >> /home/test/mysysbench.log

5、清理数据

sysbench ./tests/include/oltp_legacy/oltp.lua --mysql-host=192.168.10.10 --mysql-port=3306 --mysql-user=root --mysql-password=123456 cleanup


http://chatgpt.dhexx.cn/article/vhY1sTUT.shtml

相关文章

CScope for programmer

http://bbs.sjtu.edu.cn/bbs0an,path,%2Fgroups%2FGROUP_3%2FGNULinux%2FSoftware%2FD95E89182%2FD5277E56B.html8、Cscope 的使用这下更厉害了, 用Cscope自己的话说 - "你可以把它当做是超过频的ctags", 其功能和强大程度可见一斑吧, 关于它的介绍我就不详细说了, …

CSP安全策略

介绍 内容安全策略 (CSP) 是一个附加的安全层&#xff0c;用于帮助检测和缓解某些类型的攻击&#xff0c;包括跨站脚本 (XSS) 和数据注入等攻击。 这些攻击可用于实现从数据窃取到网站破坏或作为恶意软件分发版本等用途。 启动方式 1. 浏览器客户端启动 <meta http-equi…

seccompptcl(pwn出题)

详细细节看这篇 https://www.anquanke.com/post/id/208364#h2-2 沙箱可以禁用一些系统调用&#xff0c;还是比较常见的感觉。 seccomp 下面这段代码用seccomp沙箱来禁用 安装相应库 sudo apt-get install libseccomp-dev具体参数啥的就不多讲了。。。看大佬的博客就行。 …

CSplitterWnd

MFC支持两种类型的拆分窗口&#xff1a;静态的和动态的。 静态拆分窗口的行列数在拆分窗口被创建时就设置好了&#xff0c;用户不能更改。但是用户可以缩放各行各列。一个静态拆分窗口最多可以包含16行16列。 要找一个使用了静态拆分窗口的应用程序&#xff0c;只要看一下windo…

【UNIX网络编程】|【07】SCTP协议探究

文章目录 1、概述2、接口模型2.1 一到一形式2.2 一到多形式 3、sctp_bindx函数4、sctp_connectx函数5、sctp_getpaddrs函数6、sctp_freepaddrs函数7、sctp_getladdrs函数8、sctp_freelpaddrs9、sctp_sendmsg10、sctp_recvmsg11、sctp_opt_info12、sctp_peeloff函数13、shudown1…

C++网络编程-tcpip协议

目录 1 tcp/ip协议族 1.1 体系结构以及主要协议 1.2 封装 1.3 分用 1.4 测试网络 1.5 arp协议工作原理 1.6 dns工作原理 1.7 socket和tcp/ip协议族的关系 2 ip协议详解 2.1 ip服务特点 2.2 ipv4头部结构 2.3 ip分片 2.4 ip路由 3 tcp协议详解 3.1 tcp服务的特点…

CSP绕过

01 比赛中常见的绕过CSP csp例子&#xff1a; <meta http-equiv"Content-Security-Policy" content"script-src self; object-src none; style-src cdn.example.org third-party.org; child-src https:">目前在比赛中常见的绕过 CSP 一般是: scri…

CS的使用

1&#xff09;首先创建服务端 命令&#xff1a;teamserver 192.168.71.130(主机IP) 123456&#xff08;随便设&#xff09; teamserver 192.168.71.130 123456 >/dev/null 2>&1 & (命令隐藏后台&#xff0c;jobs查看后台&#xff0c;客户端同理&#xff0c;在st…

C/C++Unix网络编程-IPC简介

IPC是进程间通信的简称。 进程、线程与信息共享 Unix进程间的信息共享的方式&#xff1a; (1) 左边的两个进程共享存留于文件系统中某个文件上的某些信息。为访问这些信息、每个进程都得穿越内核(例如read、write、lseek等)。当一个文件有待更新时&#xff0c;某种形式的同步…

CTP For Python

GitHub地址&#xff1a;https://github.com/shizhuolin/PyCTP 这是程序化期货交易上期ctp接口版本.将其包装为python版本. 支持python3 编译需求:vs2010/gcc 编译方法 python setup.py build PyCTP 编译方法 开发环境&#xff1a;windows 10 64bit, python 3.4.3 32bit, Visu…

CSP-S 2021

[CSP-S 2021] 括号序列 题目描述 小 w 在赛场上遇到了这样一个题&#xff1a;一个长度为 n n n 且符合规范的括号序列&#xff0c;其有些位置已经确定了&#xff0c;有些位置尚未确定&#xff0c;求这样的括号序列一共有多少个。 身经百战的小 w 当然一眼就秒了这题&#x…

CyberSploit:1

一、环境搭建 靶机下载地址&#xff1a;https://www.vulnhub.com/entry/cybersploit-1,506/ 二、漏洞复现 探测靶机ip地址&#xff0c;得到靶机IP地址 nmap扫描服务以及端口&#xff0c;发现80和22端口 访问80端口&#xff0c;看到一个页面&#xff0c;查看源码未发现东西 …

[网络安全]dSploit-Android系统下的网络分析和渗透套件的使用

一、准备工作 一台已经获得root权限的安卓手机&#xff0c;并且安卓系统版本在 2.3 以上 busyBox 安装软件 下载地址 BusyBox 是一个集成了一百多个最常用linux命令和工具的软件。&#xff3b;百度百科&#xff3d; 安装这个软件主要是为dsploit软件的运行提供 linux 中…

记一次无线渗透

用到的工具 一台root的安卓手机&#xff08;我这台手机刷了miui9&#xff09; Csploit 安卓渗透神器 下载地址&#xff1a;https://github.com/cSploit/android/releases Kali meterpreter 当然你有Kali的Nethunter设备更好 开始测试 利用万能钥匙找一波wifi&#xff0c;运气好…

为网络安全红队方向提供的资源,工具大合集(渗透测试)

这是一份必备的资源大合集&#xff0c;收录了最优秀的网络安全红队方向&#xff08;渗透测试&#xff09;的资源和工具。 &#xff08;文末领取读者福利&#xff09; 无论您是初学者还是专业人士&#xff0c;都能从中获得所需的技能和知识。 在这个信息化时代&#xff0c;网络…

如何在网站中插入视频

&#xfeff;&#xfeff; 很多新手站长在往自己网站里&#xff0c;添加土豆优酷等视频网站里的视频时&#xff0c;会遇到一些麻烦,珊珊在这里向大家介绍一种简单方法. 1.首先要找到要插入的视频&#xff0c;如下图点击分享给朋友右侧的小按钮. 2.点击按钮后弹出一个窗口点击复…

Word中轻松插入本地视频

场景 在Word文档中插入视频 实现 新建或打开Word文档 找到上面插入菜单栏&#xff0c;点击并选择对象 点击后选择PPT 点击确定 此时会打开PPT&#xff0c;然后再选择上面的插入 选择插入下的视频选项&#xff0c;然后选择PC上的视频 选择视频后点击插入 可以调整视频大小 …

如何在html里插入视频

第一步&#xff1a;首先下载video.js&#xff0c;百度一下就能找到。 这个是下载后的目录。 第二步&#xff1a;先把要用到的js\css\swf都加载到html页面上。 如&#xff1a; 第三步&#xff1a;加入下面的代码&#xff1a; <video id"my_video_1" class"…

制作往图片里插入视频,视频添加到图片上播放

在视频中还有个小视频同时播放&#xff0c;这种画中画的效果以前都学习过&#xff0c;那在图片上插入视频播放&#xff0c;可以用媒体梦工厂中的画中画功能来制作吗&#xff1f;这个肯定是可以的了。下面就来看看怎么的操作的吧。 先来看看图片加视频制作出来的画中画效果 制作…

插入视频--使用<video>标签为网页添加视频

使用方法 举例 显示结果 在网页上添加视频和添加音频的标签属性用法相同。 讲解 1.autoplay:如果出现该属性&#xff0c;则视频在就绪后马上播放。 2.controls:如果出现该属性&#xff0c;则向用户显示控件&#xff0c;比如播放按钮。 3.loop:如果出现该属性&#xff0c;…