首页 > 系统相关 >Linux系统下的压测工具

Linux系统下的压测工具

时间:2024-12-09 15:55:03浏览次数:6  
标签:stress 压测 sudo dev -- 测试 Linux 工具 tc

作为一名运维人员,你是否遇到过这种场景?需要用工具测试系统cpu或内存占用高来触发告警,或者通过压测测试服务的并发能力。作为运维工程师,也可以通过这些命令复现故障场景。那么通过本文可以让你掌握常用的测试命令和工具。

一、前言

部分场景下,定位和复现项目问题需要使用工具进行系统压测,模拟和还原故障现场。那么测试或者压测工具就派上用场了,下面我们分不同场景来模拟工具的使用。

二、测试工具

2.1 网络限速工具tc

tc 是 Linux 中用于配置网络参数的命令行工具,通过它可以模拟不同网络状况,实现网络限速的效果。 使用场景:网络限速工具常用于模拟弱网络环境,测试系统在低带宽或高延迟情况下的性能。 用法举例: 复制代码
  # 设置延时30ms
  sudo tc qdisc add dev eth0 root netem delay 30ms  
  # 范围内延时(10-50ms)
  sudo tc qdisc add dev eth0 root netem delay 30ms 20ms 
  #设置丢包10%
  sudo tc qdisc add dev eth0 root netem loss 10%
  #删除丢包设置
  sudo tc qdisc del dev eth0 root netem loss 10%  
  # 显示延时的设置 :
  sudo tc qdisc show
  sudo tc qdisc show dev eth0
  # 修改延时:
  sudo tc qdisc change dev eth0 root netem delay 40ms
  #随机产生1%的重复数据包
  sudo tc qdisc add dev eth0 root netem duplicate 1%
  #设置数据包乱序
  sudo tc qdisc change dev eth0 root netem delay 10ms reorder 25% 50%
  # 删除延时
  sudo tc qdisc del dev eth0 root netem delay 40ms
复制代码

实测效果,我们设置主机丢包延迟40ms,修改前延迟如下

 设置延迟40ms

 [root@knode1 ~]# sudo tc qdisc add dev ens33 root netem delay 40ms  
 [root@knode1 ~]# sudo tc qdisc show dev ens33
 qdisc netem 8002: root refcnt 2 limit 1000 delay 40.0ms

再次ping测试,效果还是很明显的,确实很好用,更多用法,小伙伴们自己去研究吧

 2.2 CPU 内存测试工具 - stress

stress 是一个 Linux 下的压力测试工具,可以模拟 CPU 和内存的高负载情况,用于测试系统的稳定性。

使用场景:CPU/内存/磁盘测试工具常用于评估系统在高负载条件下的稳定性,检测系统的性能极限。此外,也可以测试告警的时候,使用stress工具来压测。

工具安装

  sudo apt-get install stress #ubuntu系统
  yum install stress  #Centos系统
然后进行 CPU 和内存的测试: 测试 CPU,持续运行 4 个进程 复制代码
  # stress --io 2 --cpu 4 --vm 2 --vm-bytes 80M --timeout 1440m
  --cpu N:
  生成 N 个工作进程来施加 CPU 负载。
  # stress --cpu 8 会创建 8 个进程,每个都尝试占用 100% 的 CPU 时间。
  --io N:
  生成 N 个工作进程来执行 I/O 操作,增加 I/O 负载。
  # stress --io 4 会创建 4 个 I/O 生成进程。
  --vm N:
  # 生成 N 个工作进程来分配内存并定期写入随机数据。
  每个进程默认分配 256MB 内存。
  --vm-bytes B:
  #指定每个 --vm 工作进程分配的内存量。
  stress --vm 2 --vm-bytes 128M 会生成 2 个工作进程,每个分配 128MB 内存。
  --hdd N:
  # 生成 N 个工作进程来执行磁盘 I/O 操作。
  stress --hdd 2 会创建 2 个磁盘 I/O 生成进程。
  --hdd-bytes B:
  # 指定每个 --hdd 工作进程写入磁盘的数据量。
  stress --hdd 1 --hdd-bytes 1G 会创建一个工作进程来写入 1GB 的数据。
  --timeout T:
  # 指定 stress 运行的时间,T 是时间,可以是秒(默认)、分钟(加 m)、小时(加 h)。
  stress --cpu 4 --timeout 30s 会在 30 秒后停止 CPU 负载测试
  # 显示详细信息,包括生成的工作进程的状态。
  --verbose:
复制代码

实验:压测4个cpu,持续时间180s

stress --cpu 4 --timeout 180s

 

 

 测试内存,分配 1GB 内存

  stress --vm 2 --vm-bytes 20G --timeout 360s
  --vm 2: 表示启动2个虚拟内存压力工作线程。
  --vm-bytes 20G: 每个工作线程使用的虚拟内存大小为20GB。
  --timeout 360s: 设置压力测试持续时间为360秒(6分钟)

 2.3 磁盘测速工具dd

dd 是一个 Linux 下的命令行工具,用于复制文件并对数据进行转换。通过它,我们可以测试硬盘的读写速度。  使用场景:硬盘测速工具常用于评估磁盘性能,选择最适合的存储方案,并检测磁盘是否存在性能瓶颈。  要测试读取速度和写入速度,可以使用dd命令的不同参数。例如,要测试读取速度,可以使用if参数从文件读取数据,而要测试写入速度,可以使用of参数将数据写入文件。  测试写入速度:
  dd if=/dev/zero of=/data/test bs=4k count=100k

这会将零数据写入/data/test文件中,测试写入速度

  dd if=/data/test of=/dev/null bs=4k
这会从/data/test文件中读取数据并将其丢弃,从而测试读取速度。 注:也可以使用fio来测磁盘速度 2.4. 流量访问压测工具 - ab ab 是 Apache 自带的一个小型工具,用于测试 HTTP 服务器的性能。 使用场景:流量访问压测工具常用于评估 Web 服务器的性能,检测系统在并发访问下的表现。 ab工具安装:
  sudo apt-get install apache2-utils #ubuntu系统
  sudo yum install httpd-tools   #Centos系统

测试网站的并发连接数

ab -c 10 -n 100 https://example.com/

这将创建10个并发连接,每个连接执行100个请求。

测试网站的请求速度

ab -n 1000 -c 100 https://example.com/

这将创建100个并发连接,总共执行1000个请求`.这时可以通过监控观察cpu和内存,用来初步评估平台的并发承载能力。

标签:stress,压测,sudo,dev,--,测试,Linux,工具,tc
From: https://www.cnblogs.com/lhxsoft/p/18595177

相关文章

  • Linux 路由三大件
    对于Linux网络,好奇心强的同学一定思考过两个问题:当我们发出一个包的时候,Linux是如何决策该从哪个网卡(假设有多个网卡)、哪个下一跳发出这个包,用什么IP作为source......当Linux收到一个包时,又是如何决定往哪里送的,是发送给本地程序、其他虚拟接口,还是转发到其他机器...........
  • Linux账号密码安全运维
    前言随着云计算厂商的兴起,云资源如ECS不再只有企业或者公司才会使用,普通人也可以自己买一台ECS来搭建自己的应用或者网站。虽然云计算厂商帮我们做了很多安全相关的工作,但并不代表我们的机器资源就绝对是安全的。要知道有很多事情是云计算厂商不能为我们做的,就比如账号密码的安......
  • Linux基础——查看软件包依赖问题
    一、查看openssh-8.2p1-29.oe2003sp4.x86_64依赖包yumdeplistopenssh|grep-A50openssh-8.2p1-29.oe2003sp4.x86_64 二、网站archlinux查看gcc相关依赖包及软件目录结构1、参考https://archlinux.org/packages/https://archlinux.org/download/2、查看gcc依赖关......
  • Linux OOM
    OOM是什么为什么会发生OOMOOM(OutofMemory)错误发生在系统内存耗尽时,无法为新的进程或现有进程分配足够的内存。具体原因包括:内存泄漏:程序在运行过程中申请了内存但没有正确释放,导致内存逐渐耗尽。内存使用过大:某些程序或进程在某一时刻申请了过多的内存,超过了系统的实......
  • Linux系统:CentOS 7 CA证书服务器部署
    在CentOS7上部署CA证书服务器需要以下步骤:安装OpenSSL:OpenSSL是一个强大的安全套接字层密码库,包含了主要的加密、哈希和证书签名算法等。使用以下命令安装:sudoyuminstallopenssl创建CA私钥:首先,我们需要创建一个私钥,用于生成CA证书。使用以下命令创建私钥:opensslgenrs......
  • 通过 ssh 配合conda 在 Linux服务器 使用 R语言
    我们使用vscode运行R语言代码ssh连接conda配置默认都会ssh连接教程:VSCode/Pycharm配置SSH远程开发(免密登录)conda配置教程:纯小白远程Linux服务器无root权限,安装condaLinux配置R语言环境#新建一个R环境condacreate-nR4.4.1r-base=4.4.1#配置R基础的环境conda......
  • 推荐10个免费的AI面试助手,求职笔试和面试辅助工具
    在这个竞争激烈的就业市场中,面试往往是求职者成功的关键。尤其是对于刚刚步入社会的大学生来说,面试技巧的缺乏可能会导致错失良机。2025年的就业市场寒冬让求职变得更加艰难,面试不通过成了许多人的痛点。今天,我要向大家介绍10款AI面试辅助工具,它们或许能成为你求职路上的得力助......
  • Linux 查看计算机各个硬件的性能: sysbench (多线程性能测试工具)
    安装Ubuntu/Debian:sudoapt-getupdatesudoapt-getinstallsysbenchCentOS/RHEL:sudoyuminstallepel-releasesudoyuminstallsysbench使用运行CPU压力测试:sysbenchcpu--threads=4run运行内存压力测试:sysbenchmemory--threads=4run运行文件IO压力......
  • Linux 常用压缩命令全解
    一、tarLinux中的tar命令是文件管理中最重要的命令之一。它是TapeArchive的缩写,用于创建和解压缩归档文件。存档文件是一种压缩文件,其中包含一个或多个捆绑在一起的文件,以便更易于访问存储和可移植性。tar只负责打包,打包是指将一大堆文件或目录捆绑成一个文件;压缩则是将一个大......
  • 【Linux探索学习】第三弹——Linux的基础指令
    前言:在前面我们已经讲了有十几个Linux的基础指令及相关的知识了,今天我们再补充几个重点的基础指令,给基础指令收个尾,为下面的内容做准备目录一、date指令时间显示设定时间时间戳二、cal指令三、find指令find指令which指令whereis指令四、grep指令五、zip/unzip指......