linux服务器磁盘性能测试(linux服务器磁盘性能测试方法)
ahcoder 2025-06-12 10:08 6 浏览
数据库是一个IO密集型的应用(在热点数据量比服务器可用内存大得多的情况下),IO的性能指标,是应用性能、用户体验的极其关键的一个因素,建议参考如下测试模型,对于FIO测试,标红的参数不能调整,对于单个服务器并发数超过1000的系统,且热点数据只有50%常驻内存的数据库服务器,要求该测试指标IOPS高于5000,吞吐量高于150MBPS。
(测试一)dd测试
dd if=/dev/zero of=test bs=32k count=40k oflag=dsync
参数详解:
- if=文件名:输入文件名,默认为标准输入。即指定源文件。
- of=文件名:输出文件名,默认为标准输出。即指定目的文件。
- ibs=bytes:一次读入bytes个字节,即指定一个块大小为bytes个字节。
obs=bytes:一次输出bytes个字节,即指定一个块大小为bytes个字节。
bs=bytes:同时设置读入/输出的块大小为bytes个字节。 - count=blocks:仅拷贝blocks个块,块大小等于ibs指定的字节数。
- oflag=DSYNC, IO模式,一般来说数据库有两种IO模型,直接IO和缓存IO。直接IO是对应的输出文件绕开Linux的内存buffer,直接写入磁盘。缓存IO是输出的文件先写入缓存,然后由操作系统的调度落盘。我们这里需要测试裸磁盘的IO,因此直接IO更具有代表性。
测试结果分析:磁盘每秒写入速度,174 MB。一共测试了1.3GB的写入,耗时7.72秒。
(测试二)fio测试
fio -filename=filename -direct=1 -iodepth 1 -thread -rw=randrw -ioengine=psync -bs=32k -size=5G -numjobs=32 -runtime=10 -group_reporting -name=mytest
参数详解:
- -filename=filename 测试输出的文件名字
- -direct=1 等同于dd的dsync,采用直接IO的模式,绕开操作系统内存buffer
- -iodepth 1 当队列深度为1时,增加队列深度,可以测试出磁盘的峰值。
- -thread 多线程方式测试。
- -rw=randrw 随机读写
- -ioengine=psync 测试过程绕过机器自带的buffer,使测试结果更真实(Linux在读写时,数据会先写到缓存,再在后台写到硬盘,读的时候也是优先从缓存中读,这样访问速度会加快,但是一旦掉电,缓存中数据就会清空,所有一种模式为DirectIO,可以跳过缓存,直接读写硬盘)
- -bs=32k 单次io的块文件大小为32K
- -size=5G 输出测试文件大小5G
- -numjobs=32 并发任务32个
- -runtime=10 测试时间为10s
- -group_reporting 关于显示结果的,汇总每个进程的信息
- -name=mytest 测试结果命名mytest
mytest: (g=0): rw=randrw, bs=(R) 32.0KiB-32.0KiB, (W) 32.0KiB-32.0KiB, (T) 32.0KiB-32.0KiB, ioengine=psync, iodepth=1
...
fio-3.7
Starting 32 threads
mytest: Laying out IO file (1 file / 5120MiB)
Jobs: 5 (f=5): [_(1),m(1),_(4),m(2),_(5),m(1),_(7),E(1),_(6),m(1),_(3)][4.4%][r=850KiB/s,w=0KiB/s][r=26,w=0 IOPS][eta 04m:18s]
mytest: (groupid=0, jobs=32): err= 0: pid=21995: Fri Oct 14 16:39:55 2022
read: IOPS=1484, BW=46.4MiB/s (48.6MB/s)(522MiB/11247msec)
clat (usec): min=43, max=1337.3k, avg=19459.88, stdev=43775.36
lat (usec): min=43, max=1337.3k, avg=19460.10, stdev=43775.36
clat percentiles (usec):
| 1.00th=[ 64], 5.00th=[ 67], 10.00th=[ 78],
| 20.00th=[ 1811], 30.00th=[ 3916], 40.00th=[ 5932],
| 50.00th=[ 8094], 60.00th=[ 11338], 70.00th=[ 15926],
| 80.00th=[ 23725], 90.00th=[ 44303], 95.00th=[ 76022],
| 99.00th=[ 191890], 99.50th=[ 248513], 99.90th=[ 455082],
| 99.95th=[ 599786], 99.99th=[1317012]
bw ( KiB/s): min= 64, max= 3776, per=3.52%, avg=1671.08, stdev=658.68, samples=638
iops : min= 2, max= 118, avg=52.17, stdev=20.58, samples=638
write: IOPS=1494, BW=46.7MiB/s (48.0MB/s)(525MiB/11247msec)
clat (usec): min=39, max=221376, avg=185.77, stdev=3436.55
lat (usec): min=39, max=221378, avg=187.98, stdev=3436.69
clat percentiles (usec):
| 1.00th=[ 61], 5.00th=[ 63], 10.00th=[ 64], 20.00th=[ 66],
| 30.00th=[ 67], 40.00th=[ 69], 50.00th=[ 70], 60.00th=[ 72],
| 70.00th=[ 74], 80.00th=[ 80], 90.00th=[ 100], 95.00th=[ 112],
| 99.00th=[ 172], 99.50th=[ 347], 99.90th=[ 47973], 99.95th=[100140],
| 99.99th=[217056]
bw ( KiB/s): min= 64, max= 4224, per=3.53%, avg=1688.79, stdev=808.51, samples=637
iops : min= 2, max= 132, avg=52.72, stdev=25.27, samples=637
lat (usec) : 50=0.21%, 100=51.21%, 250=6.12%, 500=0.50%, 750=0.41%
lat (usec) : 1000=0.23%
lat (msec) : 2=1.76%, 4=4.90%, 10=12.53%, 20=10.18%, 50=7.60%
lat (msec) : 100=2.73%, 250=1.37%, 500=0.20%, 750=0.03%
cpu : usr=0.06%, sys=0.35%, ctx=33902, majf=0, minf=7
IO depths : 1=100.0%, 2=0.0%, 4=0.0%, 8=0.0%, 16=0.0%, 32=0.0%, >=64=0.0%
submit : 0=0.0%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.0%, 64=0.0%, >=64=0.0%
complete : 0=0.0%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.0%, 64=0.0%, >=64=0.0%
issued rwts: total=16693,16811,0,0 short=0,0,0,0 dropped=0,0,0,0
latency : target=0, window=0, percentile=100.00%, depth=1
Run status group 0 (all jobs):
READ: bw=46.4MiB/s (48.6MB/s), 46.4MiB/s-46.4MiB/s (48.6MB/s-48.6MB/s), io=522MiB (547MB), run=11247-11247msec
WRITE: bw=46.7MiB/s (48.0MB/s), 46.7MiB/s-46.7MiB/s (48.0MB/s-48.0MB/s), io=525MiB (551MB), run=11247-11247msec
Disk stats (read/write):
dm-2: ios=16798/16827, merge=0/0, ticks=328943/2649, in_queue=337201, util=99.19%, aggrios=16797/16828, aggrmerge=0/0, aggrticks=335346/2655, aggrin_queue=338244, aggrutil=99.22%
sdb: ios=16797/16828, merge=0/0, ticks=335346/2655, in_queue=338244, util=99.22%
相关推荐
- linux服务器--PVE(一)简介及安装(pve安装ifupdown2)
-
1.PVE(ProxmoxVirtualEnvironment)简介ProxmoxVirtualEnvironment基于debian,是一个完整的、开源的企业虚拟化服务器管理平台。它在一个平...
- 手把手教你!如何在 Linux 服务器中搭建 Sentinel 环境?
-
你在Linux服务器上搭建Sentinel环境时,是不是也遇到过各种报错,要么是启动失败,要么是配置后无法正常访问控制台?看着同事顺利搭建好,自己却一头雾水,别提多着急了!其实,很多互联网大厂...
- Linux高性能服务器技术总结(linux高性能服务器编程怎么样)
-
1服务器简介服务器是提供计算服务的设备,由于服务器需要响应用户请求,因此在处理能力、稳定性、安全性、可扩展性、可管理性等方面提出了较高要求。随着虚拟化技术的进步,云服务器(ECS)已经快速的在...
- 从 0 到 1:使用 Ansible 自动化运维 Linux 服务器全流程
-
Ansible是一款强大的IT自动化工具,广泛用于服务器配置管理、软件部署和任务自动化。本文将带你从零开始,学习如何使用Ansible对Linux服务器进行自动化运维,涵盖Ansibl...
- 诡异!Win11 “此电脑” 莫名现 Linux 图标,啥情况?
-
我这电脑出了个怪事儿,“此电脑”下面莫名其妙多了个Linux的图标,可我压根儿就没装过Linux系统啊!琢磨了一下,估计是系统可选功能里那个“适用于Linux的Windows子系统”插件搞的鬼。实例系...
- Linux基础运维篇:Linux 终端与 Shell 基础(第006课)
-
一、啥是终端?先搞懂「人和电脑对话的窗口」你可以把终端(Terminal)理解成一个「文字版的电脑操作台」。在Windows里,类似「命令提示符」或PowerShell;在Linux里,...
- 2025罗技大师系列智「简」大赛-罗技大师系列-MX KEYS S键盘评测
-
在2025罗技大师系列智「简」大赛中,MXKEYSS键盘凭借其卓越的设计与智能化体验,成为众多创作者的理想之选。本篇文章将深入评测这款键盘的核心功能、使用体验及创新亮点,帮助你了解它如何提升...
- Linux编辑命令vim(linux使用vim编辑文件)
-
1、vi编辑器简介vim是一个全屏幕纯文本编辑器,是vi编辑器的增强版,我们主要讲解的是vim编辑器。可以利用别名让输入vi命令的时候,实际上执行vim编辑器,例如:#定义别名...
- 全选是ctrl加什么?全选的快捷键是什么介绍
-
如何高效使用「全选」快捷键(Ctrl+A/A)提升工作效率在日常电脑操作中,"全选"是最基础却至关重要的功能之一。无论您是文字工作者、程序员还是普通用户,掌握全选快捷键都能极大提升操作...
- Linux命令大全(linux命令大全书)
-
个人博客:https://chunyu.work/文章较长,可以收藏备用常用快捷键(1)ctrl+c:停止进程(2)ctrl+l:清屏(3)善于用tab键(4)上下键:查找执行过的命令文件目录类(...
- Xshell是做什么用的?Xshell使用教程分享
-
Xshell是一款功能强大的终端模拟器,支持SSH1,SSH2,SFTP,TELNET,RLOGIN和SERIAL。通过提供业界先进的性能,Xshell包含了其他SSH客户端无法发现的功能和优势,作为...
- Java 开发者线上问题排查常用的 15 个 Linux 命令
-
作为Java开发者,线上环境的问题排查是日常工作的重要组成部分。熟练掌握Linux命令能大幅提升排查效率,快速定位进程异常、日志错误、性能瓶颈等核心问题。本文结合Java应用特点,整理1...
- Linux的常用命令就是记不住,怎么办?
-
1.帮助命令1.1help命令#语法格式:命令--help#作用:查看某个命令的帮助信息#示例:#ls--help查看ls命令的帮助信息#netst...
- 别再乱学 Linux 了!这 5 个核心技巧,让你效率飙升 10 倍!
-
在Linux学习的漫漫长路上,不少人犹如在黑暗中摸索的行者,四处碰壁,学习效果却不尽如人意。你是不是也曾在海量的Linux知识面前迷失方向,感觉自己投入了大量时间,却收效甚微?其实,掌握Li...
- Linux终端神器Terminator时隔1年回归,2.1.5新版发布
-
IT之家5月23日消息,科技媒体linuxiac今天(5月23日)发布博文,报道称Terminator在沉寂一年后,最新发布了2.1.5版本,在分割终端窗格时支持克隆SSH...
- 一周热门
- 最近发表
-
- linux服务器--PVE(一)简介及安装(pve安装ifupdown2)
- 手把手教你!如何在 Linux 服务器中搭建 Sentinel 环境?
- Linux高性能服务器技术总结(linux高性能服务器编程怎么样)
- 从 0 到 1:使用 Ansible 自动化运维 Linux 服务器全流程
- 诡异!Win11 “此电脑” 莫名现 Linux 图标,啥情况?
- Linux基础运维篇:Linux 终端与 Shell 基础(第006课)
- 2025罗技大师系列智「简」大赛-罗技大师系列-MX KEYS S键盘评测
- Linux编辑命令vim(linux使用vim编辑文件)
- 全选是ctrl加什么?全选的快捷键是什么介绍
- Linux命令大全(linux命令大全书)
- 标签列表
-
- linux 远程 (37)
- u盘 linux (32)
- linux 登录 (34)
- linux 路径 (33)
- linux 文件命令 (35)
- linux 是什么 (35)
- linux 界面 (34)
- 查看文件 linux (35)
- linux 语言 (33)
- linux代码 (32)
- linux 查看命令 (33)
- 关闭linux (34)
- root linux (33)
- 删除文件 linux (35)
- linux 主机 (34)
- linux与 (33)
- linux 函数 (35)
- linux .ssh (35)
- cpu linux (35)
- 查看linux 系统 (32)
- linux 防火墙 (33)
- linux 手机 (32)
- linux 镜像 (34)
- linux ip地址 (34)
- linux 用户查看 (33)