[转帖]dd 自动压测与结果解析脚本
测试串行、并发、读、写 4类操作,每类操作又可以指定各种bs及count值,循环压测。每种场景一般执行3次,取平均值。
一、 串行写
-
#!/bin/sh
-
-
bs_list=(256k 1024k 10M 20M 50M 100M 1G)
-
cnt_list=(40000 10000 1000 500 200 100 10)
-
-
for i in {0..6}
-
do
-
-
for j in {0..2}
-
do
-
-
logfile=dd_${bs_list[$i]}_cnt${cnt_list[$i]}_${j}.txt
-
-
echo -e "test ${j} started\n" > $logfile
-
echo -e "started time `date`\n" >> $logfile
-
-
dd if=/dev/zero of=testfile1 bs=${bs_list[$i]} count=${cnt_list[$i]} oflag=direct,nonblock 2>> $logfile
-
-
echo -e "\nfinished time `date`" >> $logfile
-
echo -e "\ntest ${j} finished" >> $logfile
-
sleep 5
-
-
done
-
-
sleep 30
-
done
二、 4并发写
-
#!/bin/sh
-
-
# ddtest_write_conc.sh
-
-
bs_list=(256k 1024k 10M 20M 50M 100M 1G)
-
cnt_list=(40000 10000 1000 500 200 100 10)
-
-
for i in {0..6}
-
do
-
-
for j in {0..2}
-
do
-
-
logfile=dd_conc_${bs_list[$i]}_cnt${cnt_list[$i]}_${j}.txt
-
-
echo -e "test ${j} started\n" > $logfile
-
echo -e "started time `date`\n" >> $logfile
-
-
for conc in {0..3}
-
do
-
{
-
dd if=/dev/zero of=testfile1 bs=${bs_list[$i]} count=${cnt_list[$i]} oflag=direct,nonblock 2>> $logfile
-
} &
-
done
-
-
wait
-
-
echo -e "\nfinished time `date`" >> $logfile
-
echo -e "\ntest ${j} finished" >> $logfile
-
sleep 5
-
-
done
-
-
sleep 30
-
done
三、 串行读
-
#!/bin/sh
-
-
# ddtest_read_serial.sh
-
-
bs_list=(256k 1024k 10M 20M 50M 100M 1G)
-
cnt_list=(40000 10000 1000 500 200 100 10)
-
-
for i in {0..6}
-
do
-
-
for j in {0..2}
-
do
-
-
logfile=dd_${bs_list[$i]}_cnt${cnt_list[$i]}_${j}.txt
-
-
echo -e "test ${j} started\n" > $logfile
-
echo -e "started time `date`\n" >> $logfile
-
-
dd if=testfile1 of=/dev/null bs=${bs_list[$i]} count=${cnt_list[$i]} iflag=direct,nonblock 2>> $logfile
-
-
echo -e "\nfinished time `date`" >> $logfile
-
echo -e "\ntest ${j} finished" >> $logfile
-
sleep 5
-
-
done
-
-
sleep 30
-
done
四、 4并发读
-
#!/bin/sh
-
-
bs_list=(256k 1024k 10M 20M 50M 100M 1G)
-
cnt_list=(40000 10000 1000 500 200 100 10)
-
-
for i in {0..6}
-
do
-
-
for j in {0..2}
-
do
-
-
logfile=dd_conc_${bs_list[$i]}_cnt${cnt_list[$i]}_${j}.txt
-
-
echo -e "test ${j} started\n" > $logfile
-
echo -e "started time `date`\n" >> $logfile
-
-
for conc in {0..3}
-
do
-
{
-
dd if=testfile1 of=/dev/null bs=${bs_list[$i]} count=${cnt_list[$i]} iflag=direct,nonblock 2>> $logfile
-
} &
-
done
-
-
wait
-
-
echo -e "\nfinished time `date`" >> $logfile
-
echo -e "\ntest ${j} finished" >> $logfile
-
sleep 5
-
-
done
-
-
sleep 30
-
done
五、 输出解析

取执行时间
cat dd_* | grep -E 'MB/s|GB/s' | awk '{ print $6 }'
取吞吐量
cat dd_* | grep -E 'MB/s|GB/s' | awk '{ print $8 }'
[转帖]dd 自动压测与结果解析脚本的更多相关文章
- [转帖]dd命令详解
dd命令详解 https://czmmiao.iteye.com/blog/1748748 之前一直对linux的命令很恐惧 现在发现 其实不是那么复杂 要仔细学习就可以了 比如 dd = disk ...
- [转帖] dd 命令图解
dd命令-->dd是disk dump的缩写,指定大小的块拷贝一个文件,同时进行指定的转换,起到一个初始化磁盘的作用 https://blog.csdn.net/jerry_1126/arti ...
- 百度brpc 压测工具rpc_press解析
1. 背景 昨天看到一段brpc中的压测代码rpc_press, 看着不错.整理一下. 发压工具的难点不是发送请求,而是要注意下面的2点: 保证能发出足够的qps,比如上万qps 控制发送合理的qps ...
- 实践作业2:黑盒测试实践——在被测系统上录制脚本 Day 5
1.处理了学生信息管理系统运行的小细节 2.总结了katalon的使用流程如下 a.在Katalon Studio中创建一个自动化测试项目. b.创建一个测试案例,用来写入所有必要的测试步骤 c.编写 ...
- ab压测返回结果解析
Server Software: Apache/2.2.25 (服务器软件名称及版本信息)Server Hostname: localhost (服务器主机名)Server ...
- SSM自测错题解析
试题解析:spring 中bean的作用域有:singleton.session.prototype.request.global Session 试题解析:使用import导入子元素需要用prope ...
- [转帖]Marvell第二代ARM处理器ThunderX2解析
Marvell第二代ARM处理器ThunderX2解析 https://www.cnbeta.com/articles/tech/853137.htm 长久以来,服务器数据中心市场一直被x86 CPU ...
- C语言深度剖析自测题8解析
#include <stdio.h> int main(void) { int a[5] = {1, 2, 3, 4, 5}; int* ptr1 = (int*)(&a ...
- Python Locust对指定网站“一键压测”
[本文出自天外归云的博客园] 前篇 前篇:Python Locust性能测试框架实践 本篇 承上——归纳过程 在前篇的基础上,我们可以利用Locust性能测试框架编写python脚本对指定网站或者接口 ...
- 日新进用户200W+,解密《龙之谷》手游背后的压测故事
2017年3月,腾讯正式于全平台上线了<龙之谷>手游,次日冲到了App Store畅销排行第二的位置,并维持到了现在.上线当日百度指数超过40万,微信游戏平台数据显示预约数780多万,而据 ...
随机推荐
- Java并发(二十二)----wait notify的正确姿势
开始之前先看看,sleep(long n) 和 wait(long n) 的区别: 1) sleep 是 Thread 的静态方法,而 wait 是 Object 的方法 2) sleep 不需要强制 ...
- Spring源码学习笔记4——BeanFactoryPostProcessor执行
一丶BeanFactoryPostProcessor是什么 Spring留给我们的一个扩展接口,在BeanDefinition加载注册完之后,并执行一些前置操作(笔记3)之后会反射生产所有的BeanF ...
- java中获取内网IP
package com.dashan.utils.iputils; import org.apache.commons.lang.StringUtils; import javax.servlet.h ...
- Python中的cls语法
在Python中,cls 是一个用于指代类本身的约定性名称,通常用作类方法(class method)中的第一个参数.cls 类似于 self,它是对类的引用,而不是对实例的引用.cls 通常在类 ...
- 开源的代名词「GitHub 热点速览」
当开发者谈论开源时,通常会想到 GitHub,它不仅仅是一个代码托管平台,更是一个汇聚了全球开发者的社交中心.过去,开发者发布一款软件后,都是在自己的小圈子里默默努力和交流,现在通过 GitHub 平 ...
- 【华为云技术分享】40%性能提升,华为云推出PostgreSQL 12 商用版
摘要:日前,华为云数据库正式推出了RDS for PostgreSQL 12版本,并开始商用.本文将从华为云RDS for PostgreSQL 12的4大特性和架构图等多方面来解读华为云Postgr ...
- 了解库开发,我们从STM32标准库开发学起
摘要:从STM32新建工程.编译下载程序出发,让新手由浅入深,尽享STM32标准库开发的乐趣. 自从CubeMX等图像配置软件的出现,同学们往往点几下鼠标就解决了单片机的配置问题.对于追求开发速度的业 ...
- 解读8大场景下Kunpeng BoostKit 使能套件的最佳能力和实践
摘要:本次鲲鹏 BoostKit 训练营为开发者介绍如何基于鲲鹏 BoostKit 使能套件实现应用性能的加速,并重点剖析性能优化技术和关键能力. 本文分享自华为云社区<[云驻共创]" ...
- HanLP — HMM隐马尔可夫模型 -- 语料库
隐马尔可可夫模型(Hidden Markov Model,HMM)是统计模型,用于描述一个含有隐含未知参数的马尔可夫过程. HMM由初始概率分布.状态转移概率分布和观测概率分布确定. BMES =&g ...
- ElasticSearch 实现分词全文检索 - filter查询
目录 ElasticSearch 实现分词全文检索 - 概述 ElasticSearch 实现分词全文检索 - ES.Kibana.IK安装 ElasticSearch 实现分词全文检索 - Rest ...