linux 磁盘读写日志,linux下测试磁盘的读写IO速度

本文介绍了在Linux系统中如何使用hdparm和dd命令来测试磁盘的读写速度,以帮助判断是否出现IO瓶颈或软件配置问题。hdparm主要用于IDE/ATA硬盘,而dd命令则可以进行简单的读写速度评估。通过实例展示了不同块大小对磁盘性能的影响,并提供了实际操作的命令和结果分析。
摘要由CSDN通过智能技术生成

有时候我们在做维护的时候,总会遇到类似于IO特别高,但不能判定是IO瓶颈还是软件参数设置不当导致热盘的问题.这时候通常希望能知道磁盘的读写速度,来进行下一步的决策.

下面是两种测试方法:

(1)使用hdparm命令这是一个是用来获取ATA/IDE硬盘的参数的命令,是由早期Linux

IDE驱动的开发和维护人员 Mark Lord开发编写的( hdparm has been written by Mark Lord

, the primary

developer and maintainer of the (E)IDE driver for Linux, with

suggestions from many

netfolk).该命令应该也是仅用于Linux系统,对于UNIX系统,ATA/IDE硬盘用的可能比较少,一般大型的系统都是使用磁盘阵列的.

使用方法很简单

# hdparm -Tt /dev/sda

/dev/sda:

Timing cached reads: 6676 MB in 2.00 seconds = 3340.18 MB/sec

Timing buffered disk reads: 218 MB in 3.11 seconds = 70.11

MB/sec

可以看到,2秒钟读取了6676MB的缓存,约合3340.18 MB/sec;

在3.11秒中读取了218MB磁盘(物理读),读取速度约合70.11 MB/sec

(2)使用dd命令这不是一个专业的测试工具,不过如果对于测试结果的要求不是很苛刻的话,平时可以使用来对磁盘的读写速度作一个简单的评估.

另外由于这是一个免费软件,基本上×NIX系统上都有安装,对于Oracle裸设备的复制迁移,dd工具一般都是首选.

在使用前首先了解两个特殊设备

/dev/null 伪设备,回收站.写该文件不会产生IO

/dev/zero 伪设备,会产生空字符流,对它不会产生IO

测试方法:

a.测试磁盘的IO写速度# time dd

if=/dev/zero of=/test.dbf bs=8k count=300000

300000+0 records in

300000+0 records out

10.59s real 0.43s user 9.40s system

# du -sm /test.dbf

2347 /test.dbf

可以看到,在10.59秒的时间里,生成2347M的一个文件,IO写的速度约为221.6MB/sec;

当然这个速度可以多测试几遍取一个平均值,符合概率统计.

b.测试磁盘的IO读速度# df

-m

Filesystem 1M-blocks Used Available Use% Mounted on

/dev/mapper/VolGroup00-LogVol00

19214 9545 8693 53% /

/dev/sda1 99 13 82 14% /boot

none 506 0 506 0% /dev/shm

# time dd if=/dev/mapper/VolGroup00-LogVol00 of=/dev/null

bs=8k

2498560+0 records in

2498560+0 records out

247.99s real 1.92s user 48.64s system

上面的试验在247.99秒的时间里读取了19214MB的文件,计算下来平均速度为77.48MB/sec

c.测试IO同时读和写的速度

# time dd if=/dev/sda1 of=test.dbf bs=8k

13048+1 records in

13048+1 records out

3.73s real 0.04s user 2.39s system

# du -sm test.dbf

103 test.dbf

上面测试的数据量比较小,仅作为参考.

相比两种方法:

前者是linux上专业的测试IDE/ATA磁盘的工具,但是使用范围有局限性;(此试验仅仅使用了测试磁盘IO的参数,对于其他参数及解释参考man手册)

后者可以通用,但不够专业,也没有考虑到缓存和物理读的区分,测试的数据也是仅作参考,不能算是权威.

################自己的测试结果##############

需要先sudo 到root,不然结果会很难看。

先来是io写:

[weidong@tempt205 /]$ sudo -s

[root@tempt205 /]# time dd if=/dev/zero

of=/test.dbf bs=8k count=300000

300000+0 records in

300000+0 records out

2457600000 bytes (2.5 GB) copied, 3.61308 seconds, 680 MB/s

real  0m4.466s

user  0m0.071s

sys  0m4.394s

所以8k的时候差不多700MB/s。接下来数据量不变,把块减小。相应地增加块的数量。

[root@tempt205 /]# time dd if=/dev/zero of=/test.dbf bs=4k

count=600000

600000+0 records in

600000+0 records out

2457600000 bytes (2.5 GB) copied, 3.64336 seconds, 675 MB/s

real  0m4.256s

user  0m0.110s

sys  0m4.145s

[root@tempt205 /]# time dd if=/dev/zero of=/test.dbf bs=1k

count=2400000

2400000+0 records in

2400000+0 records out

2457600000 bytes (2.5 GB) copied, 7.56941 seconds, 325 MB/s

real  0m26.948s

user  0m0.163s

sys  0m8.387s

1k的时候io写性能明显不行了。原因是这块硬盘Block Size是4096

[root@tempt205 /]# tune2fs -l /dev/mapper/VolGroup00-LogVol03 |

grep "Block size"

Block size:  4096

接下来是io读测试。

[root@tempt205 /]# time dd if=/dev/mapper/VolGroup00-LogVol00

of=/dev/null bs=8k

4374528+0 records in

4374528+0 records out

35836133376 bytes (36 GB) copied, 87.3469 seconds, 410 MB/s

real  1m27.357s

user  0m0.109s

sys  0m38.295s

[root@tempt205 /]# time dd if=/dev/mapper/VolGroup00-LogVol00

of=/dev/null bs=4k

8749056+0 records in

8749056+0 records out

35836133376 bytes (36 GB) copied, 93.2633 seconds, 384 MB/s

real  1m33.265s

user  0m0.139s

sys  0m43.089s

[root@tempt205 /]# time dd if=/dev/mapper/VolGroup00-LogVol00

of=/dev/null bs=1k

34996224+0 records in

34996224+0 records out

35836133376 bytes (36 GB) copied, 111.637 seconds, 321 MB/s

real  1m51.641s

user  0m0.352s

sys  1m21.849s

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值