stress工具使用指南和结果分析

0.1152019.05.13 09:17:35字数 547阅读 1,112

#stress
`stress' imposes certain types of compute stress on your system Usage: stress [OPTION [ARG]] ...
#-? 显示帮助信息
-?, --help show this help statement
--version show version statement
#-v 显示版本号
-v, --verbose be verbose
#-q 不显示运行信息
-q, --quiet be quiet
#-n 显示已完成的指令情况
-n, --dry-run show what would have been done
#-t --timeout N 指定运行N秒后停止
#--backoff N 等待N微妙后开始运行
-t, --timeout N timeout after N seconds
--backoff N wait factor of N microseconds before work starts
#-c 产生n个进程 每个进程都反复不停的计算随机数的平方根
-c, --cpu N spawn N workers spinning on sqrt()
#-i 产生n个进程 每个进程反复调用sync(),sync()用于将内存上的内容写到硬盘上
-i, --io N spawn N workers spinning on sync()
#-m --vm n 产生n个进程,每个进程不断调用内存分配malloc和内存释放free函数
#--vm-bytes B 指定malloc时内存的字节数 (默认256MB)
#--vm-hang N 指定在free钱的秒数
-m, --vm N spawn N workers spinning on malloc()/free()
--vm-bytes B malloc B bytes per vm worker (default is 256MB)
--vm-stride B touch a byte every B bytes (default is 4096)
--vm-hang N sleep N secs before free (default none, 0 is inf)
--vm-keep redirty memory instead of freeing and reallocating
#-d --hadd n 产生n个执行write和unlink函数的进程
#-hadd-bytes B 指定写的字节数
#--hadd-noclean 不unlink
-d, --hdd N spawn N workers spinning on write()/unlink()
--hdd-bytes B write B bytes per hdd worker (default is 1GB) Example: stress --cpu 8 --io 4 --vm 2 --vm-bytes 128M --timeout 10s #时间单位可以为秒s,分m,小时h,天d,年y,文件大小单位可以为K,M,G
Note: Numbers may be suffixed with s,m,h,d,y (time) or B,K,M,G (size).

stress cpu 测试

stress测试cpu,是在用户态将cpu 耗尽。

[root@jiangyi01.sqa.zmf /home/ahao.mah/ALIOS_QA/tools/stress-1.0.4]
#stress -c 1 -t 100
stress: info: [17223] dispatching hogs: 1 cpu, 0 io, 0 vm, 0 hdd
 
image.png

stress io 测试

使用stress测试IO,虽然可以创建任意数量的IO进程,但是,可以将 %sys 100%。因为,stress是通过循环执行sync(),使得内核态cpu 100%,但是,stress,没有把w_await svctm 的比例打的很高。

[root@jiangyi01.sqa.zmf /home/ahao.mah/ALIOS_QA/tools/stress-1.0.4]
#stress --io 100 -t 100
stress: info: [130998] dispatching hogs: 0 cpu, 100 io, 0 vm, 0 hdd
[root@jiangyi01.sqa.zmf /home/ahao.mah/gotby/C/c4]
#ps axu | grep stress |grep -v grep | wc -l
101
 
image.png
 
image.png

stress mem测试

stress 测试内存的时候,--vm-bytes 1G --vm-hang 100 这里2个参数是关键!!!!
--vm-bytes 表示malloc分配多少内存
--vm-hang 表示malloc分配的内存多少时间后在free()释放掉
--vm 指定进程数量

下面例子,就是说,10个进程,同时去malloc分配内存,并且保持100s后再释放内存

[root@jiangyi01.sqa.zmf /home/ahao.mah/ALIOS_QA/tools/stress-1.0.4]
#stress --vm 10 --vm-bytes 1G --vm-hang 100 --timeout 100s
stress: info: [32286] dispatching hogs: 0 cpu, 0 io, 10 vm, 0 hdd
[root@jiangyi01.sqa.zmf /home/ahao.mah/ALIOS_QA/tools/stress-1.0.4]
#echo "63709272/1024/1024" |bc
60
 
image.png
 
image.png
[root@jiangyi01.sqa.zmf /home/ahao.mah/ALIOS_QA/tools/stress-1.0.4]
#stress --vm 30 --vm-bytes 1G --vm-hang 50 --timeout 50s
stress: info: [44047] dispatching hogs: 0 cpu, 0 io, 30 vm, 0 hdd
 
image.png
 
image.png

stress 磁盘IO测试

注意: 我是在/data 目录,这个目录挂载的是raid,总大小:17T

-d forks
--hdd forks 产生多个执行write()函数的进程
--hdd-bytes bytes 指定写的Bytes数,默认是1GB
--hdd-noclean 不要将写入随机ASCII数据的文件Unlink
eg:stress -d 1 --hdd-bytes 3G

解释:-d 1:一个写进程。写入固定大小通过mkstemp()函数写入当前目录;你也可以指定向磁盘中写入固定大小的文件
这个文件通过调用mkstemp()产生并保存在当前目录下,默认是文件产生后就被执行unlink(清除)操作,
但是你可以使用“--hdd-bytes”选项将产生的文件全部保存在当前目录下,这会将你的磁盘空间逐步耗尽。
0

当只有一个进程在写:

[root@jiangyi01.sqa.zmf /data]
#stress --hdd 1 --hdd-bytes 1024G
stress: info: [130229] dispatching hogs: 0 cpu, 0 io, 0 vm, 1 hdd
 
image.png

测试,提高进程数量为5:

[root@jiangyi01.sqa.zmf /data]
#stress --hdd 5 --hdd-bytes 1024G
stress: info: [26847] dispatching hogs: 0 cpu, 0 io, 0 vm, 5 hdd
 
image.png
[root@jiangyi01.sqa.zmf /data]
#stress --hdd 10 --hdd-bytes 1024G
stress: info: [31912] dispatching hogs: 0 cpu, 0 io, 0 vm, 10 hdd
[root@jiangyi01.sqa.zmf /home/ahao.mah]
#ps axu | grep stress | grep -v grep
root 31912 0.0 0.0 7264 652 pts/0 S+ 13:13 0:00 stress --hdd 10 --hdd-bytes 1024G
root 31913 13.9 0.0 8164 1120 pts/0 D+ 13:13 0:06 stress --hdd 10 --hdd-bytes 1024G
root 31914 14.5 0.0 8164 1120 pts/0 D+ 13:13 0:07 stress --hdd 10 --hdd-bytes 1024G
root 31915 14.5 0.0 8164 1120 pts/0 D+ 13:13 0:07 stress --hdd 10 --hdd-bytes 1024G
root 31916 14.1 0.0 8164 1120 pts/0 D+ 13:13 0:07 stress --hdd 10 --hdd-bytes 1024G
root 31917 13.9 0.0 8164 1120 pts/0 D+ 13:13 0:06 stress --hdd 10 --hdd-bytes 1024G
root 31918 14.0 0.0 8164 1120 pts/0 D+ 13:13 0:07 stress --hdd 10 --hdd-bytes 1024G
root 31919 13.8 0.0 8164 1120 pts/0 D+ 13:13 0:06 stress --hdd 10 --hdd-bytes 1024G
root 31920 13.9 0.0 8164 1120 pts/0 D+ 13:13 0:06 stress --hdd 10 --hdd-bytes 1024G
root 31921 13.9 0.0 8164 1120 pts/0 D+ 13:13 0:06 stress --hdd 10 --hdd-bytes 1024G
root 31922 14.0 0.0 8164 1120 pts/0 D+ 13:13 0:07 stress --hdd 10 --hdd-bytes 1024G
 
image.png

结论:

可见,--hdd 进程数量,并不是一个干扰因素,这个stress对写磁盘的速度并没有一个控制,直接用最大的压力测试出瓶颈,当瓶颈到达了,进程多几个也是没有什么用,这个估计也是stress的不足之处。
w_await 和svctm 基本一致,说明等待时间和服务时间基本相等。

 

stress工具使用指南和结果分析(好好好测试通过)的更多相关文章

  1. stress工具使用指南和结果分析

    stress介绍 #stress `stress' imposes certain types of compute stress on your system Usage: stress [OPTI ...

  2. C#最佳工具集合:IDE、分析、自动化工具等

    C#是企业中广泛使用的编程语言,特别是那些依赖微软的程序语言.如果您使用C#构建应用程序,则最有可能使用Visual Studio,并且已经寻找了一些扩展来对您的开发进行管理.但是,这个工具列表可能会 ...

  3. AutoConfig工具使用指南

    转载:http://blog.csdn.net/fighterandknight/article/details/70245905 13.1. 需求分析 13.1.1. 解决方案 13.2. Auto ...

  4. 性能工具之stress工具使用教程(带源码说明)

      stress是一个在linux下的压力测试小工具. 我看到有些人用这个工具来描述一些资源耗尽的场景,也有人用它来做混沌测试中.请使用者要注意,这个工具并不是模拟业务问题的,是模拟系统级问题的.所以 ...

  5. 使用COSBench工具对ceph s3接口进行压力测试--续

    之前写的使用COSBench工具对ceph s3接口进行压力测试是入门,在实际使用是,配置内容各不一样,下面列出 压力脚本是xml格式的,套用UserGuide文档说明,如下 有很多模板的例子,在co ...

  6. Chrome开发者工具使用指南

    前言 工欲善其事,必先利其器. 在前端工作中,我们常常使用到Chrome开发者工具去做各种各样的事情. 但是您真的了解这些开发者工具吗? 官方文档还是挺详细的:chrome-devtools文档. 但 ...

  7. 【Android端 APP 内存分析】使用工具进行APP的内存分析

    Android端可以通过adb 命令直接获取内存信息,当然Android studio也提供了对内存的监控分析工具,并且后续可以结合MAT做分析 今天介绍的是通过Android studio和MAT工 ...

  8. 【教程】手把手教你如何利用工具(IE9的F12)去分析模拟登陆网站(百度首页)的内部逻辑过程

    [前提] 想要实现使用某种语言,比如Python,C#等,去实现模拟登陆网站的话,首先要做的事情就是使用某种工具,去分析本身使用浏览器去登陆网页的时候,其内部的执行过程,内部逻辑. 此登陆的逻辑过程, ...

  9. 使用Linux的命令行工具做简单的文本分析

    Basic Text Analysis with Command Line Tools in Linux | William J Turkel 这篇文章非常清楚的介绍了如何使用Linux的命令行工具进 ...

随机推荐

  1. day-05-字典

    字典的初识 why: 列表可以存储大量的数据,但数据之间的关联性不强 列表的查询速度比较慢.数量越大查询越慢 what:容器型数据类型:dict how: 数据类型的分类(可变与不可变) 可变(不可哈 ...

  2. [Fundamental of Power Electronics]-PART II-8. 变换器传递函数-8.4 变换器传递函数的图形化构建

    8.4 变换器传递函数的图形化构建 第7章推导出的buck变换器小信号等效电路模型在图8.55中再次给出.让我们用上一节的图解方法来构造该变换器的传递函数和端阻抗. Fig. 8.55 Small-s ...

  3. 201871030127-王明强 实验三 结对项目—《D{0-1}KP 实例数据集算法实验平台》项目报告

    项目 内容 课程班级博客链接 18级卓越班 这个作业要求链接 实验三 软件工程结对项目 我的课程学习目标 1.熟悉PSP流程2. 熟悉github操作3.加深对D{0-1}问题的解法的理解4.熟悉ja ...

  4. 中小型前端团队代码规范工程化最佳实践 - ESLint

    前言 There are a thousand Hamlets in a thousand people's eyes. 一千个程序员,就有一千种代码风格.在前端开发中,有几个至今还在争论的代码风格差 ...

  5. 机器学习--PR曲线, ROC曲线

    在机器学习领域,如果把Accuracy作为衡量模型性能好坏的唯一指标,可能会使我们对模型性能产生误解,尤其是当我们模型输出值是一个概率值时,更不适宜只采取Accuracy作为衡量模型性泛化能的指标.这 ...

  6. (一)LDAP 简介

    一  LDAP  简介 LDAP是一种通讯协议,LDAP支持TCP/IP.协议就是标准,并且是抽象的.在这套标准下,AD(Active Directory)是微软出的一套实现.    AD 暂且把它理 ...

  7. Prime Ring Problem UVA - 524

    A ring is composed of n (even number) circles as shown in diagram. Put natural numbers 1,2,...,n int ...

  8. Day06_29_Static关键字

    Static 关键字 * Static 关键字的用法 - static既可以修饰变量(全局变量和局部变量),又可以修饰方法.static类型的变量称为静态变量,如果不初始化则编译器自动初始化为0 - ...

  9. 注册中心与API网关不是这样用的!

    之前在做顾问和咨询项目的时候,见到了一种非常经典的关于API网关和注册中心的错误用法.这个案例在我的星球里已经分享过,没想到最近又碰到了两个类似的使用姿势.也许这样的问题还存在不少团队的应用中,所以拿 ...

  10. Spring Cloud & Alibaba 实战 | 第十二篇: 微服务整合Sentinel的流控、熔断降级,赋能拥有降级功能的Feign新技能熔断,实现熔断降级双剑合璧(JMeter模拟测试)

    目录 一. Sentinel概念 1. 什么是Sentinel? 2. Sentinel功能特性 3. Sentinel VS Hystrix 二. Docker部署Sentinel Dashboar ...