网站首页 > 技术文章 正文
一、stress简介
1、stress简介
stress是Linux的一个压力测试工具,可以对CPU、Memory、IO、磁盘进行压力测试。
2、stress安装
安装:
sudo yum install stress
二、stress使用
1、stress命令
stress [OPTION [ARG]]
-c, --cpu N:产生N个进程,每个进程都循环调用sqrt函数产生CPU压力。-i, --io N:产生N个进程,每个进程循环调用sync将内存缓冲区内容写到磁盘上,产生IO压力。通过系统调用sync刷新内存缓冲区数据到磁盘中,以确保同步。如果缓冲区内数据较少,写到磁盘中的数据也较少,不会产生IO压力。在SSD磁盘环境中尤为明显,很可能iowait总是0,却因为大量调用系统调用sync,导致系统CPU使用率sys 升高。-m, --vm N:产生N个进程,每个进程循环调用malloc/free函数分配和释放内存。 --vm-bytes B:指定分配内存的大小 --vm-stride B:不断的给部分内存赋值,让COW(Copy On Write)发生 --vm-hang N :指示每个消耗内存的进程在分配到内存后转入睡眠状态N秒,然后释放内存,一直重复执行这个过程 --vm-keep:一直占用内存,区别于不断的释放和重新分配(默认是不断释放并重新分配内存)-d, --hdd N:产生N个不断执行write和unlink函数的进程(创建文件,写入内容,删除文件) --hdd-bytes B:指定文件大小
--hdd-noclean:不要将写入随机ASCII数据的文件Unlink-t, --timeout N:在N秒后结束程序 --backoff N:等待N微秒后开始运行-q, --quiet:程序在运行的过程中不输出信息-n, --dry-run:输出程序会做什么而并不实际执行相关的操作--version:显示版本号-v, --verbose:显示详细的信息
2、CPU测试
stress --cpu 2 --timeout 60
开启2个CPU进程执行sqrt计算,60秒后结束
3、IO测试
stress --io 2 --timeout 60s
开启2个IO进程,执行sync系统调用,刷新内存缓冲区到磁盘
使用stress无法模拟iowait升高,但sys升高。stress -i参数表示通过系统调用sync来模拟IO问题,但sync是刷新内存缓冲区数据到磁盘中,以确保同步。如果内存缓冲区内没多少数据,读写到磁盘中的数据也就不多,没法产生IO压力。使用SSD磁盘的环境中尤为明显,iowait一直为0,但因为大量系统调用,导致系统CPU使用率sys升高。
stress --io 2 --hdd 2 --timeout 60s
开启2个IO进程,2个磁盘IO进程
4、Memory测试
stress --vm 2 --vm-bytes 1G --vm-hang 100 --timeout 100s
开启2个进程分配内存,每次分配1GB内存,保持100秒后释放,100秒后退出。
5、磁盘IO测试
stress --hdd 2 --hdd-bytes 10G --backoff 2000000
开启2个磁盘IO进程,每次写10GB数据到磁盘
三、stress测试场景
1、CPU密集型进程
stress --cpu 2 --timeout 600
模拟启动2个CPU密集型进程
uptime
查看系统平均负载,如下:
mpstat -P ALL 5 1
查看CPU使用情况,如下:
pidstat -u 5
查看进程负载情况,如下:
(1)通过uptime可以观察系统平均负载较高。
(2)通过mpstat观察到CPU0和CPU2的用户态CPU使用率很高,而iowait为0,说明进程是CPU密集型。进程使用CPU密集导致系统平均负载变高、CPU使用率变高。
(3)可以通过pidstat查看是stress进程导致CPU使用率较高。
2、IO密集型进程
stress -i 1 --hdd 1 --timeout 600
模拟1个worker调用sync刷新内存缓冲区write到磁盘。
uptime
查看系统平均负载,如下:
mpstat -P ALL 5
查看CPU使用情况,如下:
(1)可以通过uptime观察到,系统平均负载很高。
(2)通过mpstat观察到内核态CPU使用率很低,但iowait很高,一直在等待IO处理,说明进程是IO密集型。进程频繁进行IO操作,导致系统平均负载很高而CPU使用率不高。
3、等待CPU进程
本机4个逻辑CPU,模拟8个进程。
stress -c 8 --timeout 600
模拟8个CPU密集型进程
uptime
查看系统平均负载,如下:
mpstat -P ALL 5
查看CPU使用率情况,如下:
pidstat -u 5
查看进程的CPU使用情况,如下:
(1)通过uptime观察到系统平均负载很高
(2)通过mpstat观察到用户态CPU使用率很高,iowait为0,说明进程是CPU密集型或者进程间存在CPU争用。
(3)通过pidstat观察到wait指标很高,说明进程间存在CPU争用,系统中存在大量进程在等待使用CPU。
四、stress-ng简介
1、stress-ng简介
stress-ng完全兼容stress, 并且在stress基础上增加数百个选项参数,支持产生各种复杂的压力。
2、stress-ng安装
stress-ng源码下载:
https://kernel.ubuntu.com/~cking/tarballs/stress-ng/
编译:
make
安装:
sudo make install
3、stress-ng命令
stress-ng [OPTION [ARG]] stress-ng --cpu 2 --cpu-method pi
产生2个worker做圆周率算法压力
stress-ng --cpu 2 --cpu-method all
产生2个worker迭代使用30多种不同的压力算法,包括pi, crc16, fft等
stress-ng --sock 2
产生2个worker调用socket相关函数产生压力
stress-ng --tsc 2
产生2个worker读取tsc产生压力
stress-ng --sock 4 --taskset 0-1,3
strss-ng将压力指定到指定CPU上
猜你喜欢
- 2025-06-04 ESL-通过事件控制FreeSWITCH(es事务控制)
- 2025-06-04 谈JVM xmx, xms等内存相关参数合理性设置
- 2025-06-04 嵌入式工程师竟然看不懂这些专业语句,那真别怪人说你菜
- 2024-07-29 聊聊sentinel的SimpleHttpCommandCenter
- 2024-07-29 正点原子I.MX6U嵌入式Linux C应用编程 第八章 信号
- 2024-07-29 WebRTC对等连接- 连接不同设备上的浏览器
- 2024-07-29 技术分享:Linux 问题故障定位(linux故障分析方法)
- 2024-07-29 10个最高频的Java NIO面试题剖析(python和java哪个更值得学)
- 2024-07-29 JAVA中的BIO、NIO、AIO分别指的是什么?懂得不防也要看看对不对
- 2024-07-29 TCP/IP协议栈在Linux内核中的运行时序分析
- 最近发表
-
- 使用这个新的 ECMAScript 运算符告别 Try/Catch!
- 抛弃 try-catch,错误处理的新方案
- 深圳尚学堂Java培训:总结java编程常用的快捷键(二)
- Try-catch speeding up my code?(speeding up)
- 能代替try catch处理异常的优雅方式
- Linux系统stress压力测试工具(linux自带的压力测试)
- ESL-通过事件控制FreeSWITCH(es事务控制)
- 谈JVM xmx, xms等内存相关参数合理性设置
- 嵌入式工程师竟然看不懂这些专业语句,那真别怪人说你菜
- 不会前端也能写官网?没问题,Devbox+Cursor 带你起飞
- 标签列表
-
- cmd/c (64)
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- sqlset (64)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)