Linux压测工具之stress和stress-ng
Tags: LinuxOSstressstress-ng压测压测工具
简介
CentOS 7的EPEL源包含了2个压力测试工具,一个是标准的stress, 另外一个是更强大的stress-ng,可以帮助模拟产生各种cpu压力。
stress-ng
是一个用于进行系统压力测试的工具,可以测试多种类型的系统资源,包括CPU
、内存、磁盘、网络、文件系统、进程等方面的性能。stress-ng
是Linux
系统下的一个开源工具,可以免费使用。
stress-ng
的特点包括:
- 支持多种类型的压力测试,包括CPU、内存、磁盘、网络、文件系统、进程等。
- 支持多种参数选项,可以指定测试的类型、数量、数据块大小、读写模式、文件系统类型、网络传输协议等。
- 支持多线程测试,可以同时测试多个资源的负载情况。
- 可以测试系统的稳定性和性能表现,评估系统的性能瓶颈。
- 可以在系统出现问题时提供诊断信息,帮助进行故障排除。
安装
1 | yum install -y stress stress-ng |
stress用法
stress参数和用法都很简单:
-c,--cpu:代表进程个数(每个进程会占用一个cpu,当超出cpu个数时,进程间会互相争用cpu)
-t,--timeout:测试时长(超出这个时间后自动退出)
-i,--io:表示调用sync(),它表示通过系统调用 sync() 来模拟 I/O 的问题;
但这种方法实际上并不可靠,因为 sync() 的本意是刷新内存缓冲区的数据到磁盘中,以确保同步。
如果缓冲区内本来就没多少数据,那读写到磁盘中的数据也就不多,也就没法产生 I/O 压力。
这一点,在使用 SSD 磁盘的环境中尤为明显,很可能你的 iowait 总是 0,却单纯因为大量的系统调用,导致了系统CPU使用率 sys 升高。
这种情况,推荐使用 stress-ng 来代替 stress。
比如, 从下面可以看出经过30秒的压力后,系统负载从0.00提升至0.57。
由于stress的压力模型非常简单,所以无法模拟任何复杂的场景,举个例子,在stress压测过程中,如果用top命令去观察,会发现所有的cpu压力都在用户态,内核态没有任何压力:
stress-ng
stress-ng完全兼容stress, 并且在此基础上通过几百个参数,可以产生各种复杂的压力, 比如:
产生2个worker做圆周率算法压力:
产生2个worker从迭代使用30多种不同的压力算法,包括pi, crc16, fft等等。
产生2个worker调用socket相关函数产生压力
产生2个worker读取tsc产生压力
除了能够产生不同类型的压力,strss-ng还可以将压力指定到特定的cpu上,比如下面的命令将压力指定到cpu 0,2,3,6: