如何使用Stress-ng工具在 Linux 上施加高 CPU 负载和压力测试

系统 Linux
今天介绍两个重要的工具:stress和stress-ng,用于在您的 Linux 系统下进行压力测试。

一、概述

在日常工作中,CPU压力测试是一项常见的工作,主要用到如下场景:

  • 微调系统上的活动。
  • 监控操作系统内核接口。
  • 测试您的Linux 硬件组件,例如 CPU、内存、磁盘设备和许多其他组件,以观察它们在压力下的性能。
  • 测量系统上不同的功耗负载。

今天介绍两个重要的工具:stress和stress-ng,用于在您的 Linux 系统下进行压力测试。

(1) stress– 是一种工作负载生成器工具,旨在让您的系统承受 CPU、内存、I/O 和磁盘压力的可配置测量。

(2) stress -ng – 是压力工作负载生成器工具的更新版本,可测试您的系统的以下功能:

  • CPU 计算
  • 驱动压力
  • I/O 同步
  • 管道 I/O
  • 缓存抖动
  • 虚拟机压力
  • socket压力
  • 进程创建和终止
  • 上下文切换属性

重要提示:强烈建议您以 root 用户权限使用这些工具,因为它们可以如此快速地对您的 Linux 机器施加压力,并避免在设计不佳的硬件上出现某些系统错误。

二、如何在 Linux 中安装stress工具

1. 安装stress

要在RHEL / CentOS和Fedora Linux上安装压力,您需要有 EPEL 存储库,然后键入以下 yum 命令进行安装:

# yum install stress

stress的使用方法:

$ sudo stress option argument
  • 要产生N个在 sqrt() 函数上运行的worker,请使用–cpu N选项。
  • 要产生N个在 sync() 函数上运行的worker,请使用–io N选项。
  • 要生成在 malloc()/free() 函数上运行的N个工作程序,请使用–vm N选项。
  • 要为每个 vm worker 分配内存,请使用–vm-bytes N选项。
  • 您可以使用–vm-keep选项重新分配内存,而不是释放和重新分配内存资源。
  • 使用–vm-hang N选项在释放内存之前将睡眠设置为N秒。
  • 要产生 N个在 write()/unlink() 函数上旋转的工作人员,请使用–hdd N选项。
  • 您可以使用–timeout N选项在N秒后设置超时。
  • 通过使用–backoff N选项在任何工作开始之前设置N微秒的等待。

2. 如何在 Linux 系统上使用stress

(1) 要检查每次运行命令的效果,首先运行uptime命令并记下平均负载。

接下来,运行压力命令以生成 8 个在sqrt()上运行的worker,超时时间为20秒。运行压力后,再次运行uptime命令并比较负载平均值。

localhost ~ $  uptime 
localhost ~ $ sudo stress --cpu 8 --timeout 20
localhost ~ $ uptime

(2) 要生成 8 个在 sqrt() 上运行且超时为30秒的worker,显示有关操作的详细信息,请运行以下命令:

localhost ~ $  uptime 
localhost ~ $ sudo stress --cpu 8 -v --timeout 30s
localhost ~ $ uptime

(3) 要生成一个具有60秒超时时间的malloc()和free()函数的worker ,请运行以下命令。

localhost ~ $  uptime 
localhost ~ $ sudo stress --vm 1 --timeout 60s
localhost ~ $ uptime

(4) 要在 sqrt() 上生成 4 个 worker,在 sync() 上生成 2 个 worker,在 malloc()/free() 上生成 2 个 worker,超时时间为 20 秒,并为每个 vm worker 分配 256MB 的内存,运行这个下面的命令:

localhost ~ $  uptime 
localhost ~ $ sudo stress --cpu 4 --io 3 --vm 2 --vm-bytes 256M --timeout 20s
localhost ~ $ uptime

三、如何在 Linux 中安装stress-ng工具

1. 安装stress-ng

要安装stress-ng,请运行以下命令:

# yum install stress-ng [在基于RedHat的系统上]

使用stress-ng的一般语法是:

$ sudo stress-ng 选项参数

您可以与stress-ng一起使用的一些选项:

  • 要启动每个压力测试的 N 个实例,请使用–all N选项,如下所示。
  • 要通过顺序执行所有不同的 CPU 压力测试方法来启动 N 个进程来锻炼 CPU,请使用–cpu N选项,如下所示。
  • 要使用给定的 CPU 压力测试方法,请使用–cpu-method选项。您可以使用许多方法,查看手册页以查看所有要使用的方法。
  • 要在 N 个 bogo 操作后停止 CPU 压力过程,请使用–cpu-ops N选项。
  • 要启动 NI/O 压力测试过程,请使用–io N选项。
  • 要在 N 个 bogo 操作后停止 io 压力过程,请使用 –io -ops N选项。
  • 要启动 N 个 vm 压力测试进程,请使用–vm N选项。
  • 要指定每个 vm 进程的内存量,请使用–vm-bytes N选项。
  • 要在 N 个 bogo 操作后停止 vm 压力进程,请使用–vm-ops N 个选项
  • 使用–hdd N选项启动 N 个硬盘运行进程。
  • 要在 N 个 bogo 操作后停止硬盘压力过程,请使用–hdd-ops N选项。
  • 您可以使用–timeout N选项在 N 秒后设置超时。
  • 要在 bogo 操作后生成摘要报告,您可以使用–metrics或–metrics-brief选项。–metrics -brief显示非零指标。
  • 您还可以使用–dir N选项启动 N 个进程,这些进程将使用 mkdir 和 rmdir 创建和删除目录。
  • 要停止目录操作进程,请使用–dir-ops N选项。
  • 要启动 N 个 CPU 消耗进程来执行当前的 nice 级别,包括
  • -nice N选项。使用此选项时,每次迭代都会派生一个子进程,该子进程会运行一个繁忙的循环,每个级别运行 0.1 秒,然后退出所有不同的 nice 级别。
  • 要停止 nice 循环,请使用–nice-ops N选项,如下所示。
  • 要启动通过 chmod(2) 和 fchmod(2) 在同一文件上更改文件模式位的 N 个进程,请使用–chmod N选项。请记住,N 的值越大,文件的争用就越多。压力源将通过您使用 chmod(2) 指定的所有模式位组合来工作。
  • 您可以通过–chmod-ops N选项停止 chmod 操作。
  • 您可以使用-v选项来显示有关正在进行的操作的更多信息。
  • 使用-h查看stress-ng 的帮助。

2. 如何在 Linux 系统中使用stress-ng

(1) 运行 8 个 CPU 压力源,超时时间为 60 秒,并在操作结束时进行汇总。

localhost:~$ uptime
localhost:~$ sudo stress-ng --cpu 8 --timeout 60 --metrics-brief
localhost:~$ uptime

(2) 运行4 个FFT CPU 压力源,超时时间为 2 分钟。

localhost:~$ uptime
localhost:~$ sudo stress-ng --cpu 4 --cpu-method fft --timeout 2m
localhost:~$ uptime

(3) 要运行 5 个硬盘压力源并在 100000 次 bogo 操作后停止,请运行此命令::

localhost:~$ uptime
localhost:~$ sudo stress-ng --hdd 5 --hdd-ops 100000
localhost:~$ uptime

(4) 要使用 1GB 虚拟内存运行 8 个 CPU 压力源、4 个 I/O 压力源和 1 个虚拟内存压力源一分钟,请运行以下命令

localhost:~$ uptime
localhost:~$ sudo stress-ng --cpu 4 --io 4 --vm 1 --vm-bytes 1G --timeout 60s --metrics-brief
localhost:~$ uptime

四、小结

这些工具应该与超级用户权限一起使用,因为它们对系统有一定的影响。这些工具适用于 Linux中的系统管理。

责任编辑:赵宁宁 来源: 今日头条
相关推荐

2022-05-05 05:55:44

Linux 系统压力测试

2015-07-27 18:19:22

Linuxstress参数

2023-06-06 16:10:11

2010-06-07 17:46:46

Linux压力测试工具

2010-05-27 18:48:20

Linux压力测试工具

2019-06-03 20:00:09

LinuxCPU温度GPU温度

2011-06-08 16:59:04

性能测试载测试压力测试

2020-05-18 07:00:00

性能测试压力测试负载测试

2012-02-08 14:16:55

Apache

2018-03-09 09:15:16

Linuxsyslog-ng日志

2018-02-26 08:14:20

LinuxDocker容器

2022-09-22 08:05:23

架构

2023-10-15 14:53:22

Arch LinuxYay

2018-12-14 08:29:56

CPU编程x86

2019-10-16 17:00:51

LinuxUbuntuVMware

2023-07-07 15:34:27

负载测试性能测试

2023-03-08 15:38:56

Linux命令dict

2014-10-09 14:35:44

HAProxy负载均衡

2019-12-05 10:30:17

LinuxMultitail

2011-03-22 10:06:27

LinuxZFS
点赞
收藏

51CTO技术栈公众号