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

别再只会用top看CPU了!手把手教你用stress-ng在Linux上模拟真实业务压力

从玩具到武器用stress-ng构建Linux压力测试的工业级方案当我们需要验证服务器在高负载下的表现时大多数人首先想到的是top命令——它确实能告诉我们CPU是否繁忙但就像用体温计测量发动机温度一样远远不够。真正的压力测试需要精确模拟生产环境中的各种极端场景数据库查询风暴、内存泄漏导致的OOM、日志洪峰引发的I/O阻塞...这就是stress-ng的价值所在——它不仅是资源消耗工具更是构建真实业务场景的瑞士军刀。1. 压力测试的认知升级从理论到实践传统认知中压力测试就是让CPU跑满、内存耗尽这种简单粗暴的方式往往与真实业务场景相去甚远。想象一下电商大促时的服务器状态不是所有CPU核心均匀满载而是某些核心处理支付网关请求达到100%其他核心可能只负载30%处理商品展示内存也不是瞬间耗尽而是随着用户会话增加缓慢攀升磁盘I/O更是呈现脉冲式波动——这些复杂场景需要更精细的模拟工具。stress-ng相比基础版stress的进化体现在三个维度压力维度支持超过60种压力源CPU缓存争用、分支预测失误、内存总线饱和等控制精度可指定压力波形阶梯增长、脉冲波动、随机扰动监控指标内置性能计数器采集L1缓存命中率、TLB缺失等硬件级指标安装最新版stress-ng的推荐方式# Ubuntu/Debian sudo apt install stress-ng # CentOS/RHEL sudo yum install epel-release sudo yum install stress-ng # 编译安装获取最新特性 wget https://kernel.ubuntu.com/~cking/tarballs/stress-ng/stress-ng-0.15.06.tar.xz tar -xvf stress-ng-0.15.06.tar.xz cd stress-ng-0.15.06 make sudo make install2. CPU压力模拟超越简单的100%负载真实业务中的CPU负载从来不是均匀分布的。以MySQL为例连接风暴可能导致大量时间花费在系统调用上而计算密集型查询又会造成浮点运算单元饱和。stress-ng的--cpu-method参数可以精确模拟这些场景方法参数模拟场景典型业务对应监控重点matrix矩阵运算机器学习推理AVX指令集利用率correlate数据相关性计算实时风控系统分支预测失误率fft快速傅里叶变换音视频处理浮点单元吞吐量syscall系统调用密集型API网关上下文切换次数crypt加密解密操作SSL/TLS处理密码学指令周期模拟支付网关的突发负载场景# 突发性负载每10秒产生持续2秒的100%负载 stress-ng --cpu 4 --cpu-method syscall --cpu-load-slice 2 --cpu-load-rise 10配合perf工具观察硬件事件perf stat -e cycles,instructions,cache-misses,branch-misses stress-ng --cpu 4 --cpu-method correlate -t 1m3. 内存压力测试制造可控的内存泄漏OOMOut Of Memory是生产环境中最棘手的故障之一。基础的内存测试往往只是简单分配大块内存而真实的内存泄漏是渐进式的。stress-ng提供了多种内存压力模式渐进式分配--vm-keep模拟内存泄漏的线性增长随机访问--vm-populate模拟缓存失效场景混合压力--vm-madvise触发内核内存回收机制Redis集群内存增长模拟方案# 模拟每个实例每小时增长2GB内存持续12小时 stress-ng --vm 16 --vm-bytes 2G --vm-stride 64 --vm-madvise willneed \ --vm-populate --timeout 12h --metrics-brief关键参数解析--vm-stride 64每64字节进行一次内存访问模拟真实缓存行--vm-madvise willneed提示内核预取内存模拟预热过程--metrics-brief定期输出内存分配速率和缺页异常统计监控建议组合watch -n 1 grep -e MemAvailable -e Swap /proc/meminfo vmstat 1 # 观察si/so交换区换入换出4. 存储I/O风暴不只是dd的替代品磁盘I/O性能对数据库系统至关重要但简单的dd测试只能反映顺序读写的最佳情况。实际业务中更多是随机读写、fsync刷盘、元数据操作等混合负载# 模拟MySQL的binlog写入模式 stress-ng --hdd 2 --hdd-bytes 1G --hdd-opts sync,dsync,fsync \ --hdd-write-size 16k --hdd-write-bytes 80% \ --timerfd --iostat 1参数组合效果sync,dsync,fsync混合使用不同级别的持久化保证--hdd-write-size 16k模拟InnoDB页大小--hdd-write-bytes 80%保持磁盘80%空间占用--iostat 1每秒输出I/O统计更真实的Kafka日志目录压力测试mkdir -p /kafka/pressure/{data,index} stress-ng --hdd 4 --hdd-dir /kafka/pressure \ --hdd-opts direct,random,keep \ --hdd-write-size 4k-16k \ --hdd-delay-us 100-500 \ --temp-path /kafka/pressure5. 复合场景构建全链路压力测试真正的业务压力从来不是孤立的。一个电商下单流程可能同时涉及CPU计算优惠券核销内存操作库存扣减磁盘写入订单落库网络通信支付网关stress-ng的场景编排功能可以模拟这种复合负载# 模拟秒杀场景持续30分钟 stress-ng --cpu 8 --cpu-method matrix \ --vm 4 --vm-bytes 8G --vm-populate \ --hdd 2 --hdd-bytes 20G \ --io 4 --timer 2 \ --timeout 30m --metrics \ --log-file ./stress.log配套的监控方案应该包括# 系统级监控 sar -A 1 1800 sar.log # 进程级监控 pidstat -d -u -r -h 1 1800 pidstat.log # 内核事件跟踪 perf record -g -a -o perf.data sleep 18006. 结果分析与调优建议压力测试的价值不在于制造崩溃而在于发现问题后的优化。stress-ng的--metrics选项会输出丰富的性能计数器典型问题诊断模式CPU饱和度但利用率低检查perf stat中的stalled-cycles-frontend可能是内存带宽瓶颈考虑NUMA优化内存充足但频繁OOM观察vmstat中的sr内存扫描速率调整vm.swappiness和透明大页配置磁盘IPS高但吞吐量低检查iostat中的avgqu-sz队列长度考虑调整调度器deadlinevsnoop调优前后对比表示例指标优化前优化后调整手段事务吞吐量1200 TPS2100 TPS关闭THP99分位延迟450ms89ms调整NUMA内存绑定CPU利用率75%68%修改CPU调度策略上下文切换次数1.2M次/分钟0.4M次/分钟优化线程池大小记住最好的压力测试工具也替代不了真实流量测试。在双11前某电商团队发现虽然stress-ng模拟的CPU/内存负载都达标但真实流量下网络中断处理成为瓶颈——这提醒我们任何工具都有局限关键是用对场景。

相关文章:

别再只会用top看CPU了!手把手教你用stress-ng在Linux上模拟真实业务压力

从玩具到武器:用stress-ng构建Linux压力测试的工业级方案 当我们需要验证服务器在高负载下的表现时,大多数人首先想到的是top命令——它确实能告诉我们CPU是否繁忙,但就像用体温计测量发动机温度一样,远远不够。真正的压力测试需要…...

CTF-MISC工具箱盘点:Steghide、010 Editor、Python脚本...这些工具如何帮你拿下‘神奇的压缩包’和‘李华的身份证’?

CTF-MISC实战工具箱:从隐写到爆破的自动化艺术 在CTF竞赛的MISC(杂项)领域,工具链的熟练程度往往决定了解题速度的上限。当面对一个看似无解的压缩包、一张隐藏关键信息的图片,或是一串意义不明的加密字符串时&#xf…...

图像质量评价指标全解析:PSNR、SSIM、NIQE、LPIPS 从原理到代码一网打尽

一、前言:为啥我们需要图像质量评价指标?不管是图像生成、超分、去模糊、去噪、修复…… 只要你改了图,就必须回答一个问题: 改得好不好?画质有没有下降?有没有失真? 靠人眼?太慢、不…...

UTM虚拟机终极指南:5分钟在iOS和macOS设备上运行Windows和Linux系统

UTM虚拟机终极指南:5分钟在iOS和macOS设备上运行Windows和Linux系统 【免费下载链接】UTM Virtual machines for iOS and macOS 项目地址: https://gitcode.com/gh_mirrors/ut/UTM 想要在iPhone、iPad或Mac上体验Windows系统吗?UTM虚拟机让你的苹…...

微信聊天记录永久保存与智能分析:3步掌握你的数字记忆主权

微信聊天记录永久保存与智能分析:3步掌握你的数字记忆主权 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/W…...

带有1D-1D出瞳扩展和真实光栅的光波导模拟

摘要随着增强与混合现实(AR&MR)领域新应用的发展,导光系统的应用越来越受到人们的关注。为了将光从光源引导到预定的眼箱,采用了分离的1D-1D扩展光瞳的结构,并结合了不同类型的表面刻蚀光栅。因此,在AR/MR器件的设计过程中&am…...

免费获取VMware Workstation Pro 17许可证密钥:5步激活完整指南

免费获取VMware Workstation Pro 17许可证密钥:5步激活完整指南 【免费下载链接】VMware-Workstation-Pro-17-Licence-Keys Free VMware Workstation Pro 17 full license keys. Weve meticulously organized thousands of keys, catering to all major versions of…...

别再死记硬背了!用Python+Matplotlib亲手画图,5分钟搞懂音频采样与量化

用Python可视化音频采样与量化:从声波到数字的魔法之旅 每次听音乐时,你是否好奇那些优美的旋律是如何被计算机存储和处理的?今天,我们将用Python的Matplotlib库,通过亲手绘制图形,揭开音频数字化的神秘面纱…...

服务容灾设计思考

服务容灾设计思考:构建高可用系统的核心策略 在数字化时代,服务的连续性和稳定性成为企业竞争力的关键。无论是金融、电商还是公共服务领域,系统宕机或数据丢失都可能造成不可估量的损失。服务容灾设计正是为了解决这一问题而生,…...

3分钟快速安装微软商店:Windows 11 LTSC系统完整指南

3分钟快速安装微软商店:Windows 11 LTSC系统完整指南 【免费下载链接】LTSC-Add-MicrosoftStore Add Windows Store to Windows 11 24H2 LTSC 项目地址: https://gitcode.com/gh_mirrors/ltscad/LTSC-Add-MicrosoftStore 你是否正在使用Windows 11 LTSC版本&…...

戴尔XPS 16评测:均衡大屏笔记本,但售价偏高

戴尔XPS 16(2026款)戴尔此次推出XPS 16,似乎有两个目标:一是重振XPS品牌——该品牌去年曾一度停售,直至今年1月在CES展上宣布回归;二是将其定位于高端内容创作笔记本(如华硕ProArt P16、联想Yog…...

php内核 内核网络请求底层限制与安全管控

PHP 内核层网络请求安全,最佳方式是“默认全拒绝,按白名单放行”,并且在 4 层一起做:内核/扩展拦截 PHP 配置 业务 SDK for shortcuts系统防火墙。────────────────────────────────────…...

php内核 内网离线编译私有PHP内核完整流程

一套能直接执行的:内网离线编译私有 PHP 内核完整流程,全大白话、偏生产可落地。先一句结论: for shortcuts最佳方式 “联…...

php内核 国产CPU(鲲鹏/海光/飞腾)编译指令集适配

“能落地”的版本:PHP 内核在国产 CPU(鲲鹏/海光/飞腾)上的编译与指令集适配最佳方式,全大白话。先一句结论: …...

php内核 内核后门防护、代码执行拦截底层加固

一个直接能落地的“防后门 拦截代码执行”方案。先说结论:最佳方式不是只改一个点,而是 4 层一起上:编译裁剪层 内核拦截层 运行时策略层 系统隔离层。 单点防护一定会漏。---一、先讲大白话:后门最…...

安全管理化技术威胁建模与风险评估

安全管理化技术威胁建模与风险评估是当今数字化时代保障信息系统安全的核心手段。随着网络攻击手段的日益复杂化,企业和组织亟需通过系统化的方法识别、分析和应对潜在威胁。本文将围绕这一主题,从威胁识别、风险量化、控制措施三个关键方面展开探讨&…...

基于安卓的社区团购团长管理系统毕设

博主介绍:✌ 专注于Java,python,✌关注✌私信我✌具体的问题,我会尽力帮助你。一、研究目的本研究旨在设计并实现一套面向社区团购团长的智能化管理系统,并通过安卓平台构建其移动端应用以提升运营效率与用户体验。随着社区团购模式在电子商务…...

基于安卓的汽车维修保养记录平台毕业设计源码

博主介绍:✌ 专注于Java,python,✌关注✌私信我✌具体的问题,我会尽力帮助你。一、研究目的本研究旨在设计并实现一个基于安卓操作系统的汽车维修保养记录管理平台以解决传统汽车维修保养过程中存在的信息管理分散、数据更新滞后及维护效率低下等问题。随…...

基于安卓的服装尺寸智能推荐系统毕设

博主介绍:✌ 专注于Java,python,✌关注✌私信我✌具体的问题,我会尽力帮助你。一、研究目的本研究旨在构建一个基于安卓平台的服装尺寸智能推荐系统以解决传统服装尺寸推荐方法在精准度与个性化适配方面的不足。随着移动互联网技术的普及与消费者对个性化…...

普通BO解映射为何不暂停队列

AMDGPU KFD 驱动中 SVM (Shared Virtual Memory) 范围 或 BO (Buffer Object) 在需要被驱逐 (evict) 或失效 (invalidate) 时,为何以及如何触发 进程级别 (per-process) 的用户队列 (user queue) 暂停 (quiesce) 与恢复 。那么“为什么一个普通的 BO 在 unmap 的时候…...

Qwen3.5-2B模型版本管理实战:Git工作流与协作规范

Qwen3.5-2B模型版本管理实战:Git工作流与协作规范 1. 为什么需要版本管理 在团队协作开发Qwen3.5-2B模型时,我们经常会遇到这样的场景:张三修改了模型参数但忘记记录具体改动,李四的实验结果无法复现,王五不小心覆盖…...

如何从SQL备份中恢复单表数据_利用特定表导入与闪回技术

直接从全库mysqldump中恢复单表需文本过滤重放:用awk精准提取目标表的CREATE TABLE和INSERT语句块,再导入;不可用INTO OUTFILE反向恢复,因其输出非SQL格式;binlog闪回需解析RBR事件,且无法恢复DROP TABLE的…...

LCM实战:用C++和Python在ROS2与机器人项目中实现进程间高效数据交换

LCM实战:用C和Python在ROS2与机器人项目中实现进程间高效数据交换 在机器人系统和自动驾驶领域,实时数据传输的效率和可靠性直接影响着系统性能。当传感器数据流、控制指令和状态信息需要在多个模块间高速交换时,传统的通信方案往往面临延迟高…...

2026年爆款实测 | 哪些降重软件可以同时降低查重率和AIGC疑似率?高效论文降重方案:TOP10平台功能对比与选择建议(推荐一些可以用于论文降重的软件)

【CSDN博主摘要】 每年五月,CSDN的私信都要被即将毕业的硕博生们挤爆。大家都在问一个极其现实且焦虑的问题:“现在的机器检测太变态了,到底推荐一些可以用于论文降重的软件?到底哪些降重软件可以同时降低查重率和AIGC疑似率&…...

别再死记硬背公式了!手把手教你理解DBC文件里的factor和offset(附CAN信号收发实战代码)

从代码反推DBC参数:工程师视角下的factor与offset实战指南 每次看到DBC文件里那些神秘的factor和offset参数,你是不是也和我当年一样,先机械地抄下公式,然后在调试时对着报错抓耳挠腮?作为在汽车电子行业摸爬滚打多年的…...

增量式知识图谱持续构建系统应用【附代码】

(1)面向火电厂故障文档的实体关系联合抽取模型: 针对故障文本中实体特征稀疏和实体嵌套问题,提出了一种融合双向编码表示与跨层记忆网络的关系抽取模型。采用预训练语言模型作为底层编码器,获取上下文相关的字向量表示…...

DoIP协议栈开发必踩的7大陷阱:从CAN迁移以太网的C++工程师速看

更多请点击: https://intelliparadigm.com 第一章:DoIP协议栈开发必踩的7大陷阱:从CAN迁移以太网的C工程师速看 当汽车电子工程师将传统CAN诊断逻辑迁移到DoIP(Diagnostics over Internet Protocol)时,看似…...

Linux 进程间通信:共享内存与消息队列完全指南

引言在Linux系统编程中,进程间通信(IPC)是多进程协作的核心技术。前面我们学习了管道,今天我们将深入讲解另外三种重要的IPC机制:共享内存、信号量和消息队列。这三种机制各有特点:共享内存:最高…...

面试官直播拷打我:“是否了解Harness Engineering?”,我笑了:“LLM很强,但如果不能拴住、监测、约束,都白搭”。面试官一直在点头。

Harness Engineering 是什么?从哪冒出来的? 面试官一般这么问:"你听说过 Harness Engineering 吗?“或者"Agent Model Harness,你怎么理解这个等式?” 先搞清楚:Harness 是什么&am…...

【独家内测数据】Copilot Next 启动耗时从2.8s压至0.41s:3步完成工作流自动化重构(附可复用JSON Schema模板)

更多请点击: https://intelliparadigm.com 第一章:Copilot Next 自动化工作流性能调优全景概览 Copilot Next 并非传统代码补全工具的简单升级,而是基于实时上下文感知、多模态意图理解与动态工作流编排能力构建的智能协同引擎。其性能表现…...