sysbench性能测试

article/2025/9/27 12:56:51

sysbench的官网地址是:http://sysbench.sourceforge.net

Step 1: 下载安装: sysbench-0.5.tar.gz 解压后展开目录如下

[root@localhost mnt]# cd  sysbench-0.5
[root@localhost sysbench-0.5]# ls
aclocal.m4  autom4te.cache  config      config.status  configure.ac  doc         libtool  Makefile     Makefile.in  mkinstalldirs  README-WIN.txt  TODO
autogen.sh  ChangeLog       config.log  configure      COPYING       install-sh  m4       Makefile.am  missing      README         sysbench
[root@localhost sysbench-0.5]#

查看README文件可以看到安装方法:

    ./autogen.sh
    ./configure
    make
    make install
 

Sysbench --help可以看到具有以下功能

Compiled-in tests:
  fileio - File I/O test  IO性能测试
  cpu - CPU performance test CPU性能测试
  memory - Memory functions speed test 内存性能测试
  threads - Threads subsystem performance test 线程子系统性能测试
  mutex - Mutex performance test  互斥测试

Step2  Sysbench CPU性能测试:

Sysbench 测试CPU是通过计算素数的加法运算,它会自动生成素数,并进行相加;一般可以指定最大值,默认10000;

我们用命令:sysbench --test=cpu --cpu-max-prime=20000 run

[root@localhost sysbench-0.5]# sysbench --test=cpu --cpu-max-prime=20000 run
sysbench 0.5:  multi-threaded system evaluation benchmark
--版本
Running the test with following options:
Number of threads: 1
--使用一个线程
Random number generator seed is 0 and will be ignored
随机数生成素数0将会被忽略Primer numbers limit: 20000
最大素数上线20000
Threads started!Test execution summary:total time:                          29.5438s  --总共花费时间total number of events:              10000     --一共计算10000次total time taken by event execution: 29.5402s  --事件(一个素数计算做一个事件)执行时间per-request statistics:min:                                  2.48ms  --最小计算花费时间avg:                                  2.95ms  --平均max:                                 56.82ms  --最大approx.  95 percentile:               3.85ms  --95%的计算花费时间Threads fairness:events (avg/stddev):           10000.0000/0.00   计算事件总数execution time (avg/stddev):   29.5402/0.00      计算花费时间总数

可以看到压测的时候CPU被sysbench占满了;

Step3: IO测试:

sysbench --test=fileio helpfileio options:--file-num=N                  number of files to create [128] 创建文件数量,默认128--file-block-size=N           block size to use in all IO operations [16384] 块儿大小,默认16384,即Innodb的存储引擎Page大小;如果要测试Innodb就用默认;--file-total-size=SIZE        total size of files to create [2G] 生成测试文件的总大小--file-test-mode=STRING       test mode {seqwr(顺序写)、seqrewr(顺序读写)、seqrd(顺序读)、rndrd(随机读)、rndwr(随机写)和rndrw(随机读写)}--file-io-mode=STRING          文件IO模式,同步/异步/快速映射/慢映射{sync,async,fastmmap,slowmmap} [sync]。--file-extra-flags=STRING     additional flags to use on opening files {sync,dsync,direct} [] 打开文件的额外选项--file-fsync-freq=N           do fsync() after this number of requests (0 - don't use fsync()) [100]执行写入fsync()的频率,fsync()用于写入数据导磁盘 默认100次请求就写入一次导磁盘--file-fsync-all=[on|off]     do fsync() after each write operation [off]  每次写操作都同步到磁盘--file-fsync-end=[on|off]     do fsync() at the end of test [on] 测试结束同步至磁盘--file-fsync-mode=STRING      which method to use for synchronization {fsync, fdatasync} [fsync]使用哪种方法写入磁盘--file-merged-requests=N      merge at most this number of IO requests if possible (0 - don't merge) [0] 合并改数量的IO请求--file-rw-ratio=N             reads/writes ratio for combined test [1.5]。 写/读组合比测试,默认1:1.5

sysbench的fileio测试需要经过prepare、run和clean三个阶段。

  1. prepare是准备阶段,生产我们需要的测试文件
  2. run是实际测试阶段
  3. cleanup是清理测试产生的文

sysbench --test=fileio --file-num=16 --file-total-size=2G prepare  生成16个测试文件,总大小2G

此时会生成测试文件,因为总大小2G,数量16个,所以每个文件约129M;

 sysbench --test=fileio --file-num=16 --file-total-size=2G  --file-test-mode=rndrw run 采用随机读写的方式测试:

[root@localhost mnt]# sysbench --test=fileio --file-num=16 --file-total-size=2G  --file-test-mode=rndrw run  --测试模式,随机读写
sysbench 0.5:  multi-threaded system evaluation benchmarkRunning the test with following options:
Number of threads: 1   --线程1个
Random number generator seed is 0 and will be ignoredThreads started!Operations performed:  6000 reads, 4000 writes, 1600 Other = 11600 Total
6000次读,4000次写(因为默认1.5:1)1600次其他操作;
Read 93.75Mb  Written 62.5Mb  Total transferred 156.25Mb  (276.57Mb/sec)
随机读了93.75M数据,写了62.5M数据 总IO 156.25M
17700.40 Requests/sec executed
每秒执行17700次
Test execution summary:total time:                          0.5650s 总耗费时间total number of events:              10000    读写次数10000次total time taken by event execution: 0.3961s   读写花费时间per-request statistics:min:                                  0.00ms 最小时间avg:                                  0.04ms 平均时间max:                                 20.24ms  最大时间approx.  95 percentile:               0.08ms  95%读写花费时间Threads fairness:events (avg/stddev):           10000.0000/0.00execution time (avg/stddev):   0.3961/0.00

sysbench --test=fileio --file-num=16 --file-total-size=2G  --file-test-mode=rndrw cleanup 最后执行clearnup清除测试数据

 

Step 4: 线程测试:

 sysbench --num-threads=64 --test=threads --thread-yields=2000 --thread-locks=2 run 

并发线程64,采用线程测试方法,每个请求产生2000个线程,每个线程锁2个;

[root@localhost sysbench-0.5]# sysbench --test=threads --num-threads=64 --thread-yields=2000 --thread-locks=2 run
sysbench 0.5:  multi-threaded system evaluation benchmarkRunning the test with following options:
Number of threads: 64  --并发线程64个
Random number generator seed is 0 and will be ignoredThreads started!Test execution summary:total time:                          15.7261s   total number of events:              10000   total time taken by event execution: 1004.5724sper-request statistics:min:                                  0.58msavg:                                100.46msmax:                               1049.29msapprox.  95 percentile:             246.15msThreads fairness:events (avg/stddev):           156.2500/7.99execution time (avg/stddev):   15.6964/0.02

Step5: 内存测试

sysbench   --num-threads=64 --test=memory --memory-block-size=8k --memory-total-size=16G --memory-scope=global --memory-access-mode=rnd run

[root@localhost sysbench-0.5]# sysbench   --num-threads=64 --test=memory --memory-block-size=8k --memory-total-size=16G --memory-scope=global --memory-access-mode=rnd run
sysbench 0.5:  multi-threaded system evaluation benchmarkRunning the test with following options:
Number of threads: 64
Random number generator seed is 0 and will be ignoredThreads started!Operations performed: 2097152 (3690132.19 ops/sec)16384.00 MB transferred (28829.16 MB/sec)Test execution summary:total time:                          0.5683stotal number of events:              2097152total time taken by event execution: 20.6291sper-request statistics:min:                                  0.00msavg:                                  0.01msmax:                                351.43msapprox.  95 percentile:               0.00msThreads fairness:events (avg/stddev):           32768.0000/8682.67execution time (avg/stddev):   0.3223/0.06[root@localhost sysbench-0.5]#

 


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

相关文章

mysql sysbench_MySQL sysbench基准测试

一、基准测试 参考《高性能 MySQL》第二章。 二、Sysbench sysbench 是开源的跨平台多线程基准测试工具,主要用于测试各种不同系统参数下的 CPU/内存/线程/IO/数据库等方面的性能,数据库目前支持 MySQL/Oracle/PostgreSQL。具体的参数设置,应…

sysbench mysql图表_sysbench_mysql

ref 测试 当执行下面这个sysbench测试mysql的时候,你不知道的可能可能是: 这到底是在测试读写?还是 读? 答: 只读 --num-threads12 啥意思? 答:就是说有12个线程在同时链接 你可以看到&#xff…

性能测试之sysbench

本期是写的测试mysql的性能测试,本人也是第一次接触mysql的性能,拿到这个任务时也是多方1查询资料, sysbench压力测试工具简介: sysbench是一个开源的、模块化的、跨平台的多线程性能测试工具,可以用来进行CPU、内存…

sysbench数据库压测工具详解与实战

sysbench是一个基于LuaJIT脚本的多线程基准测试工具。2004年由Peter Zaitsev(Percona公司创始人)开发,在其0.5版本中可以使用Lua脚本实现OLTP测试。2016年重构了sysbench代码,并在2017年2月针对新的硬件环境发布了1.0版本&#xf…

sysbench 介绍

sysbench介绍 参考博客: sysbench - 老僧观天下 - 博客园 sysbench 压测 详解_俗人linux_51CTO博客 sysbench工具使用 - ZhenXing_Yu - 博客园 |QQ:327488733qq.com sysbench使用指南 - AhaoMu - 博客园 MySql性能测试工具-sysbench_oahz4699092zhao的专栏-CS…

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

一、sysbench简介 1、sysbench简介 sysBench是一个模块化的、跨平台、多线程基准测试工具,主要用于评估测试各种不同系统参数下的数据库负载情况。sysbench提供如下测试: (1)CPU性能 (2)磁盘IO性能 &…

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;运气好…