Linux压测工具之stress和stress-ng

0    74    1

Tags:

👉 本文共约3959个字,系统预计阅读时间或需15分钟。

简介

CentOS 7的EPEL源包含了2个压力测试工具,一个是标准的stress, 另外一个是更强大的stress-ng,可以帮助模拟产生各种cpu压力。

stress-ng是一个用于进行系统压力测试的工具,可以测试多种类型的系统资源,包括CPU、内存、磁盘、网络、文件系统、进程等方面的性能。stress-ngLinux系统下的一个开源工具,可以免费使用。

stress-ng的特点包括:

  • 支持多种类型的压力测试,包括CPU、内存、磁盘、网络、文件系统、进程等。
  • 支持多种参数选项,可以指定测试的类型、数量、数据块大小、读写模式、文件系统类型、网络传输协议等。
  • 支持多线程测试,可以同时测试多个资源的负载情况。
  • 可以测试系统的稳定性和性能表现,评估系统的性能瓶颈。
  • 可以在系统出现问题时提供诊断信息,帮助进行故障排除。

安装

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。

Linux压测工具之stress和stress-ng

由于stress的压力模型非常简单,所以无法模拟任何复杂的场景,举个例子,在stress压测过程中,如果用top命令去观察,会发现所有的cpu压力都在用户态,内核态没有任何压力:

Linux压测工具之stress和stress-ng

stress-ng

stress-ng完全兼容stress, 并且在此基础上通过几百个参数,可以产生各种复杂的压力, 比如:

产生2个worker做圆周率算法压力:

Linux压测工具之stress和stress-ng

产生2个worker从迭代使用30多种不同的压力算法,包括pi, crc16, fft等等。

Linux压测工具之stress和stress-ng

产生2个worker调用socket相关函数产生压力

Linux压测工具之stress和stress-ng

产生2个worker读取tsc产生压力

Linux压测工具之stress和stress-ng

除了能够产生不同类型的压力,strss-ng还可以将压力指定到特定的cpu上,比如下面的命令将压力指定到cpu 0,2,3,6:

Linux压测工具之stress和stress-ng

本人提供Oracle(OCP、OCM)、MySQL(OCP)、PostgreSQL(PGCA、PGCE、PGCM)等数据库的培训和考证业务,私聊QQ646634621或微信db_bao,谢谢!
Linux压测工具之stress和stress-ng后续精彩内容已被小麦苗无情隐藏,请输入验证码解锁本站所有文章
验证码:
请关注本站微信公众号,回复“小麦苗博客”,获取验证码。在微信里搜索“DB宝”或者“www_xmmup_com”或者微信扫描右侧二维码都可以关注本站微信公众号。

标签:

Avatar photo

小麦苗

学习或考证,均可联系麦老师,请加微信db_bao或QQ646634621

您可能还喜欢...

发表回复

嘿,我是小麦,需要帮助随时找我哦
  • 18509239930
  • 个人微信

  • 麦老师QQ聊天
  • 个人邮箱
  • 点击加入QQ群
  • 个人微店

  • 回到顶部