stress 服务器压力测试的工具学习

一、stress 工具介绍

tress 是一种工具,可以对符合 POSIX 标准的操作系统施加可配置数量的 CPU、内存、I/O 或磁盘压力,并报告其检测到的任何错误。

stress 不是一个基准测试。它是由系统管理员用来评估其系统扩展性的工具,由内核程序员用来评估感知性能特征,以及由系统程序员用来暴露只有在系统负载高时才会出现或更频繁出现的错误类别。

二、安装stress

stress项目 git地址:https://github.com/resurrecting-open-source-projects/stress.git

在ubuntu22.04上安装stress

stress目前没有提供安装包,需要下载源码编译安装

  1. 下载编译环境

    bash 复制代码
    root@stress:~# apt-get install gcc g++ make
  2. 将stress源码克隆下来

    github项目拉取不下来可以考虑使用gitee仓库地址:https://gitee.com/cyhjf/stress.git

    bash 复制代码
    root@stress:~# git clone https://gitee.com/cyhjf/stress.git
  3. 编译安装

    bash 复制代码
    root@stress:~# cd stress/
    root@stress:~/stress# ./autogen.sh
    ./autogen.sh: 51: autoreconf: not found
    We have a problem...

    缺少autoreconf命令,下载后继续编译

    autoreconf 是一个用于重新配置源代码树的工具,主要用于基于 autotools(autoconf、automake

    等)构建系统的项目。它会自动运行 autoconf、automake、aclocal 等命令,重新生成 configure

    脚本和相关的构建文件,确保项目的构建系统是完整和正确的。这在项目源代码有更新后,需要重新生成构建配置文件时非常有用。

    bash 复制代码
    root@stress:~/stress# apt -y install autoconf
    root@stress:~/stress# ./autogen.sh
    root@stress:~/stress# ./configure
    root@stress:~/stress# make && make install
    root@stress:~/stress# stress --version
    stress 1.0.7

三、压力测试

stress不提供测试报告,只是压测工具,让服务器处理高压状态暴露出可能出现的错误。

stress参数介绍

bash 复制代码
OPTIONS
       -?, --help
              显示此帮助说明。
       --version
              显示版本声明。
       -v, --verbose
              详细展示
       -q, --quiet
              安静模式
       -n, --dry-run
              查看执行效果,并非已经执行
       -t, --timeout <N>
              超时时间
       --backoff <N>
              在开始工作前先等待微秒级的时间。
       -c, --cpu <N>
              启动 N 个线程,这些线程会持续执行 sqrt() 函数。
       -i, --io <N>
             启动 N 个工作进程,让它们在"sync()"函数上进行运行。
       -m, --vm <N>
              启动若干个工作进程,它们会持续执行内存分配(malloc)和释放(free)操作。
       --vm-bytes <B>
              每个虚拟机工作进程分配字节内存(默认值为 256MB)。
       --vm-stride <B>
              每个字节操作一次(默认值为 4096)
       --vm-hang <N>
              在释放资源前先睡眠 N 秒(默认情况为无延迟,即 0 秒)。
       --vm-keep
              重新使用已损坏的内存,而非进行释放和重新分配操作。
       -d, --hdd <N>
              启动若干个工作进程,它们将执行写入/删除操作。
       --hdd-bytes <B>
             每个 HDD 工作进程写入 B 字节的数据(默认值为 1GB)。该文件将在当前目录中通过 mkstemp() 函数创建。
             
       Note: 数字可能后缀有"s"(秒)、"m"(分钟)、"h"(小时)、"d"(天)、"y"(年)(表示时间)或"B"(字节)、"K"(千字节)、
  1. 测试cpu负载

    查看本机cpu核心数

    bash 复制代码
    root@stress:~/stress# lscpu | grep "On-line"
    On-line CPU(s) list:                  0,1

    开启8个线程,开另一个窗口执行 top -id 1查看cpu负载情况

    默认每个进程都在执行数学运算(计算质数)通过这种方式来模拟 CPU 的高负载,用于测试 CPU 的性能以及在高负载情况下的稳定性等。

    bash 复制代码
    stress --cpu 8 --timeout 60s 
  2. 测试磁盘 io

    创建 4 个io进程,2个写并删除进程,指定每个进程写入100MB 文件并删除,开启另一个窗口使用 vmstat -n 1 持续监控

    bash 复制代码
    stress --io 4 --hdd 2 --hdd-bytes 100M --timeout 60s
  3. 测试内存

    启动2个进程它们会持续执行内存分配(malloc)和释放(free)操作,每个进程分配1G,持续60s

    bash 复制代码
    stress --vm 2 --vm-bytes 1G --vm-keep -t 60s
相关推荐
zx_zx_1239 分钟前
网络的学习 2 Socket
服务器·网络·学习
rannn_11130 分钟前
【MySQL学习|黑马笔记|Day3】多表查询(多表关系、内连接、外连接、自连接、联合查询、子查询),事务(简介、操作、四大体系、并发事务问题、事务隔离级别)
数据库·笔记·后端·学习·mysql
Lovyk38 分钟前
Cockpit管理服务器
linux·运维·服务器
醉卧红尘的鱼42 分钟前
最优估计准则与方法(5)加权最小二乘估计(WLS)_学习笔记
学习·算法
开开心心就好1 小时前
PDF转图片工具,一键转换高清无损
服务器·前端·智能手机·r语言·pdf·excel·batch
失因1 小时前
Linux 进程管理与计划任务设置
linux·运维·服务器·网络
leafpipi1 小时前
【机器学习】pycharm使用SSH SFTP 远程连接 ubuntu服务器 进行开发+调试+数据训练
服务器·学习·算法·ubuntu·pycharm·ssh
Chef_Chen2 小时前
从0开始学习R语言--Day62--RE插补
开发语言·学习·r语言
★YUI★2 小时前
学习游戏制作记录(冻结敌人时间与黑洞技能)7.30
学习·游戏·unity·c#
sealaugh322 小时前
aws(学习笔记第五十课) ECS集中练习(2)
笔记·学习·aws