百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

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...