[转帖]Windows磁盘性能压测(1)-DiskSpd
http://www.manongjc.com/detail/59-xrydhtisrajqsxn.html
目录
一、腾讯云官网硬盘性能指标介绍
二、使用DiskSpd测试硬盘性能指标
1. DiskSpd工具介绍
2. 单路随机读写时延测试
2.1测试硬盘的随机读时延
2.2测试硬盘的随机写时延
2.3测试硬盘的随机读写时延
3. 硬盘吞吐性能测试
3.1测试硬盘的顺序读吞吐性能
3.2测试硬盘的顺序写吞吐性能
3.3测试硬盘的顺序混合读写吞吐性能
4. 硬盘IOPS性能测试
4.1测试硬盘的随机读IOPS
4.2测试硬盘的随机写IOPS
4.3测试硬盘的随机混合读写IOPS
说明:
有关Windows磁盘性能压测,笔者还是强烈推荐使用微软自己开源的压测工具DiskSpd。当然,如果要使用其他磁盘性能压测工具也是可以的,比如:IOMeter(老牌经典)、FIO(更适合Linux)等。
一、腾讯云官网硬盘性能指标介绍
https://cloud.tencent.com/document/product/362/2353
通常使用以下指标来衡量硬盘的性能:
IOPS:每秒读/写次数,单位为次(计数),存储设备的底层驱动类型决定了不同的 IOPS;
吞吐量:每秒的读写数据量,单位为MB/s;
时延:I/O 操作的发送时间到接收确认所经过的时间,单位为秒。
|
性能指标 |
增强型SSD云硬盘 |
SSD云硬盘 |
高性能云硬盘 |
|---|---|---|---|
|
单盘最大容量(GB) |
32000 |
32000 |
32000 |
|
单盘最大 IOPS |
100000 |
26000 |
6000 |
|
随机 IOPS 性能计算公式 |
基准性能:随机IOPS = min{1800 + 存储容量(GB)× 50,50000 } 额外性能:最大 IOPS = min{128 × 额外性能值,50000} 详情请参见增强型SSD云硬盘性能说明 |
随机 IOPS = min{1800 + 存储容量(GB)× 30,26000} |
随机 IOPS = min{1800 + 存储容量(GB)× 8,6000} |
|
单盘最大吞吐量(MB/s) |
1000MB/s |
260MB/s |
150MB/s |
|
吞吐性能计算公式(MB/s) |
基准性能:吞吐 = min{120 + 存储容量(GB)× 0.5,350} 额外性能:吞吐 = min{1 × 额外性能值,650} 详情请参见增强型 SSD云硬盘性能说明 |
吞吐 = min{120 + 存储容量(GB)× 0.2,260} |
吞吐 = min{100 + 存储容量(GB)× 0.15,150} |
|
单路随机读写时延 |
0.3 - 1ms |
0.5 - 3ms |
0.8- 4ms |
二、使用DiskSpd测试硬盘性能指标
1. DiskSpd工具介绍
https://github.com/microsoft/diskspd/releases 工具下载
https://github.com/Microsoft/diskspd 源码
https://github.com/Microsoft/diskspd/wiki/Command-line-and-parameters 参数
最常用参数介绍:
|
参数名 |
说明 |
|---|---|
|
-b<size> [K|M|G] |
表示块大小(以字节、KiB、MiB 或 GiB为单位),默认块大小为 64 KiB。 |
|
-c<size>[K|M|G|b] |
设置测试中创建使用的示例文件大小。 可以按字节、KiB、MiB、GiB 或块进行设置。 |
|
-D<milliseconds> |
捕获 IOPS 统计信息(例如标准偏差),时间间隔为毫秒[default=1000,1second]。 |
|
-d<seconds> |
指定测试的持续时间,不包括冷却或预热时间。 默认值为 10 秒,但对于任何繁重的工作负荷,建议至少使用 60 秒。 |
|
-L |
度量延迟统计信息。 |
|
-o<count> |
表示每个线程的每个目标的未完成 I/O 请求数, 也称为队列深度。 |
|
-r<align>[K|M|G|b] |
随机 I/O 对齐测试,默认值为4K,不加-r为顺序I/O测试。 |
|
-Suw |
禁用软件和硬件写入缓存(等效于 -Sh)。 |
|
-t<count> |
表示每个目标的线程数,默认是单线程。 |
|
-w<percentage> |
指定属于写入请求操作的百分比(不写-w或-w或者-w0 等效于100%读取)。 如:-w25代表有25%的写,75%的读。 |
注意,以下示例为测试1块500G高性能云硬盘的整体性能。
2. 单路随机读写时延测试
-b4k -o1,随机读/写测试,能反映硬盘的时延性能
2.1测试硬盘的随机读时延
.diskspd.exe -o1 -b4k –r4k -w0 -d120 -Sh -D -L -c10G D:targetfileIO.dat
2.2测试硬盘的随机写时延
.diskspd.exe -o1 -b4k -r4k -w100 -d120 -Sh -D -L -c10G D:targetfileIO.dat
2.3测试硬盘的随机读写时延
.diskspd.exe -o1 -b4k -r4k -w50 -d120 -Sh -D -L -c10G D:targetfileIO.dat
以上测试结果显示,平均延迟为0.717毫秒
3. 硬盘吞吐性能测试
-b128k -o32,顺序读/写测试,能反映硬盘的吞吐性能
3.1测试硬盘的顺序读吞吐性能
.diskspd.exe -o32 -b128k -w0 -d120 -Sh -D -L -c10G D:targetfileIO.dat
3.2测试硬盘的顺序写吞吐性能
.diskspd.exe -o32 -b128k -w100 -d120 -Sh -D -L -c10G D:targetfileIO.dat
3.3测试硬盘的顺序混合读写吞吐性能
.diskspd.exe -o32 -b128k -w50 -d120 -Sh -D -L -c10G D:targetfileIO.dat
以上测试结果显示,硬盘吞吐接近最大值150MB/s
4. 硬盘IOPS性能测试
-b4k -o32,随机读/写测试,能反映硬盘的IOPS性能
4.1测试硬盘的随机读IOPS
.diskspd.exe -o32 -b4k -r4k -w0 -d120 -Sh -D -L -c10G D:targetfileIO.dat
4.2测试硬盘的随机写IOPS
.diskspd.exe -o32 -b4k -r4k -w100 -d120 -Sh -D -L -c10G D:targetfileIO.dat
4.3测试硬盘的随机混合读写IOPS
.diskspd.exe -o32 -b4k -r4k -w50 -d120 -Sh -D -L -c10G D:targetfileIO.dat
以上测试结果显示,IOPS也符合预期5800(1800+500G*8)
截止目前,磁盘性能测试已基本结束。
总结:
不同测试工具测试结果难免略有偏差,但从以上测试结果来看,基本符合预期。另外,DiskSpd输出结果非常丰富,本文只是截取其中一部分关键测试结果用于展示。
[转帖]Windows磁盘性能压测(1)-DiskSpd的更多相关文章
- 性能压测诡异的Requests/second 响应刺尖问题
最近一段时间都在忙着转java项目最后的冲刺,前期的coding翻代码.debug.fixbug都逐渐收尾,进入上线前的性能压测. 虽然不是大促前的性能压测要求,但是为了安全起见,需要摸个底心里有个数 ...
- windows下Jmeter压测端口占用问题(亲测有效)
windows下Jmeter压测端口占用问题 1 报错信息描述 压测的初期,在设置了 150qps/s 的并发数下压测几分钟后 Jmeter 就出现了如下报错. JAVA.NET.BINDEXCEPT ...
- MySQL 性能压测工具-sysbench,从入门到自定义测试项
sysbench是一个开源的.基于LuaJIT(LuaJIT 是 Lua 的即时编译器,可将代码直接翻译成机器码,性能比原生 lua 要高) 的.可自定义脚本的多线程基准测试工具,也是目前用得最多的 ...
- jmeter系列-如何实现像loadrunner一样,多个并发用户先通过登录初始化,然后做并发的接口性能压测
自动转开发后,就很少关注性能测试方面的东西,最近在帮朋友做一个性能压测,由于朋友那边的公司比较小,环境比较简单,而且是对http服务进行的压测,所以最终 选用了jmeter来实现这个压测. 如下就是我 ...
- 性能压测,SQL查询异常
早上测试对性能压测,发现取sequence服务大量超时报错,查询线上的监控SQL: 大量这个查询,我在DeviceID和Isdelete上建有复合索引,应该很快,而且我测试了一下,取值,执行效率很高, ...
- jmeter性能压测瓶颈排查-网络带宽
问题: 有一台机器做性能压测的时候,无论开多少个线程,QPS一直压不上去,而服务器和数据库的性能指标(主要是CPU和内存)一直维持在很低的水平. 希望帮忙排查一下原因. 过去看了下进行压测的接口代码, ...
- 性能压测中的SLA,你知道吗?
本文是<Performance Test Together>(简称PTT)系列专题分享的第6期,该专题将从性能压测的设计.实现.执行.监控.问题定位和分析.应用场景等多个纬度对性能压测的全 ...
- 并发模式与 RPS 模式之争,性能压测领域的星球大战
本文是<如何做好性能压测>系列专题分享的第四期,该专题将从性能压测的设计.实现.执行.监控.问题定位和分析.应用场景等多个纬度对性能压测的全过程进行拆解,以帮助大家构建完整的性能压测的理论 ...
- [SCF+wetest+jmeter]简单云性能压测工具使用方案
前言 压测太难?局域网压力无法判断服务器网络指标?无法产生非常大的并发量?云性能太贵? 也许我们可以把各种简单的工具拼起来进行压力测试! 准备 https://cloud.tencent.com/pr ...
- 软件性能测试分析与调优实践之路-JMeter对RPC服务的性能压测分析与调优-手稿节选
一.JMeter 如何通过自定义Sample来压测RPC服务 RPC(Remote Procedure Call)俗称远程过程调用,是常用的一种高效的服务调用方式,也是性能压测时经常遇到的一种服务调用 ...
随机推荐
- 标准物模型:设备无缝对接,IOT界的福音
摘要:信息模型是解决IoT产业发展一系列挑战的关键,在信息模型的基础上可以推进行业标准/架构的统一,进而实现产业链生态的协同. 本文分享自华为云社区<[云驻共创]标准物模型,物联网的福音> ...
- 有了这个告警系统,DBA提前预警不是难题
摘要:告警功能是各大云平台必不可少的模块,个性化的告警配置,为帮助用户和运维人员及时发现问题发挥着重要作用. 本文分享自华为云社区<GaussDB(DWS) 数据库智能监控系统告警框架上线啦!& ...
- MultipartFile与File的一些事
摘要:某段时间碰到了中转文件的需求,需要使用HttpClient中转一下文件,在实现这个需求的过程中就用得到了MultipartFile与File. 本文分享自华为云社区<MultipartFi ...
- docker镜像列表存在但删除显示 No such image问题解决
近期使用了docker,但删除镜像时候遇到了无法删除问题.提示:No such Image.原因有两个,解决方法如下: 原因1: 容器还存在是无法删除镜像的 解决步骤: 1.停掉容器(docker s ...
- 听说火山引擎推出的 DataLeap,已经可以支持万级表的数据血缘图谱了!
更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群 数据来源广.量级大.场景多,导致数据之间关系变得异常复杂. 经过读取.清洗.存储.计算等一系列流程之后,数据最终汇 ...
- Appium常用定位方法讲解
Appium常用定位方法讲解 对象定位是自动化测试中很关键的一步,也可以说是 最关键的一步,毕竟你对象都没定位那么你想操作也不行,下面我们来看常用的一些定位方式. ID定位(取resource-id的 ...
- Open vSwitch系列之十 调用北向接口下发流表
Open vSwitch系列之一 Open vSwitch诞生 Open vSwitch系列之二 安装指定版本ovs Open vSwitch系列之三 ovs-vsctl命令使用 Open vSwit ...
- 我“采访”了 ChatGPT
我"采访"了 ChatGPT 大家好,我是准备认真码字的**老章:. 最近ChatGPT火的爆表,看了很多相关文章,特别焦虑,唯恐自己的进步赶不上 AI 的发展. 还有就是我非常看 ...
- 用Python制作高逼格数学动画manim
简介 manim是斯坦福大学数学系小哥Grant Sanderson开源的数学仿真模拟python库,并用于YouTube 频道3Blue1Brown,来解说高等数学. manim是一个非常优秀的数学 ...
- HanLP — HMM隐马尔可夫模型 -- 维特比(Viterbi)算法 --示例代码 - Java
Viterbi 维特比算法解决的是篱笆型的图的最短路径问题,图的节点按列组织,每列的节点数量可以不一样,每一列的节点只能和相邻列的节点相连,不能跨列相连,节点之间有着不同的距离,距离的值就不在 题目背 ...