当前位置: 首页 > news >正文

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. 下载编译环境

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

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

    root@stress:~# git clone https://gitee.com/cyhjf/stress.git
    
  3. 编译安装

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

    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参数介绍

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核心数

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

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

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

    stress --cpu 8 --timeout 60s 
    
  2. 测试磁盘 io

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

    stress --io 4 --hdd 2 --hdd-bytes 100M --timeout 60s
    
  3. 测试内存

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

    stress --vm 2 --vm-bytes 1G --vm-keep -t 60s
    
http://www.lqws.cn/news/114571.html

相关文章:

  • 无字母数字webshell的命令执行
  • xcode 各版本真机调试包下载
  • ShardingSphere-JDBC 与 Sharding-JDBC 的对比与区别
  • JVM——类加载的流程与机制
  • 【HarmonyOS Next之旅】DevEco Studio使用指南(三十)
  • 【映射】2024-睿抗-AcWing 5834. 谁进线下了?
  • 从OSI到TCP/IP:网络协议的演变与作用
  • 鸿蒙任务项设置案例实战
  • EasyRTC嵌入式音视频通信SDK音视频功能驱动视频业务多场景应用
  • 计算机视觉处理----OpenCV(从摄像头采集视频、视频处理与视频录制)
  • 【android bluetooth 协议分析 14】【HFP详解 1】【案例一: 手机侧显示来电,但车机侧没有显示来电: 讲解AT+CLCC命令】
  • 【后端】RPC
  • Android 项目的核心配置文件
  • 在VSCode中开发一个uni-app项目
  • Linux RPC 和 NFS 教程
  • 湖北理元理律师事务所:债务化解中的心理重建与法律护航
  • 【Java算法】八大排序
  • Lifecycle 核心原理面试回答
  • 得物GO面试题及参考答案
  • NLP学习路线图(二十四):门控循环单元(GRU)
  • QT聊天项目DAY13
  • Tauri(2.5.1)+Leptos(0.7.8)开发桌面应用--简单的工作进度管理
  • 英福康INFICON VGC501, VGC502, VGC503 单通道、双通道和三通道测量装置
  • 【Harmony OS】数据存储
  • pytorch基本运算-导数和f-string
  • 【分布式技术】KeepAlived高可用架构科普
  • Vert.x学习笔记-EventLoop与Handler的关系
  • 电脑安装系统蓝屏的原因
  • 1. 引言
  • CSS(2)