CN105893230A - 一种检测硬盘iops性能的方法及装置 - Google Patents

一种检测硬盘iops性能的方法及装置 Download PDF

Info

Publication number
CN105893230A
CN105893230A CN201610204390.3A CN201610204390A CN105893230A CN 105893230 A CN105893230 A CN 105893230A CN 201610204390 A CN201610204390 A CN 201610204390A CN 105893230 A CN105893230 A CN 105893230A
Authority
CN
China
Prior art keywords
hard disk
target
target hard
iops
successively
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN201610204390.3A
Other languages
English (en)
Inventor
刘凤刚
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Inspur Electronic Information Industry Co Ltd
Original Assignee
Inspur Electronic Information Industry Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Inspur Electronic Information Industry Co Ltd filed Critical Inspur Electronic Information Industry Co Ltd
Priority to CN201610204390.3A priority Critical patent/CN105893230A/zh
Publication of CN105893230A publication Critical patent/CN105893230A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3452Performance evaluation by statistical analysis
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3003Monitoring arrangements specially adapted to the computing system or computing system component being monitored
    • G06F11/3037Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system component is a memory, e.g. virtual memory, cache

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Computing Systems (AREA)
  • General Physics & Mathematics (AREA)
  • Quality & Reliability (AREA)
  • Bioinformatics & Cheminformatics (AREA)
  • Computer Hardware Design (AREA)
  • Probability & Statistics with Applications (AREA)
  • Evolutionary Biology (AREA)
  • Bioinformatics & Computational Biology (AREA)
  • Life Sciences & Earth Sciences (AREA)
  • Mathematical Physics (AREA)
  • Debugging And Monitoring (AREA)

Abstract

本发明提供了一种检测硬盘IOPS性能的方法及装置,应用于Linux系统,该方法包括:确定计算机中需要进行IOPS性能检测的至少一个目标硬盘,并设定对各个所述目标硬盘进行访问的访问形式;根据所述访问形式,依次对各个所述目标硬盘进行读操作或写操作;对所述读操作或写操作过程进行监控,形成对应的记录文件;根据所述记录文件,获取各个所述目标硬盘对应的IOPS数据。该装置包括:设定单元、检测单元、监控单元及提取单元。本方案能够提高对硬盘IOPS性能进行测试的效率。

Description

一种检测硬盘IOPS性能的方法及装置
技术领域
本发明涉及计算机技术领域,特别涉及一种检测硬盘IOPS性能的方法及装置。
背景技术
硬盘是计算机必不可少的存储设备,用于存储计算机系统文件及用户数据,硬盘的性能将直接影响计算机的性能,特别是在服务器中,为了保证服务器的稳定性及运算速度,硬盘的稳定性必须得到保证。因此,用户提出了一系列针对硬盘的测试项目,以对硬盘的稳定性进行测试,其中硬盘测试项目中包括对硬盘读写操作速度IOPS进行测试,以检测硬盘的IOPS性能。
目前,在检测硬盘的IOPS性能时,在Windows系统下,通过工作负载生成器Iometer对服务器的各个硬盘进行读写操作,从而获取各个硬盘的IOPS数据。
针对于现有技术对硬盘IOPS性能进行检测的方法,在Windows系统下,通过Iometer对服务器的各个硬盘进行读写操作时,经常出现Iometer显示的硬盘位置与硬盘在机箱中的实际位置不对应的现象,导致无法确定获得的各个IOPS数据与各个硬盘的对应关系,因而需要逐个对各个硬盘进行热插拔,以确定Iometer显示的各个硬盘的真实安装位置,从而确定各个IOPS数据与各个硬盘的对应关系。这样,在硬盘数量较多时,需要耗费大量时间确定Iometer显示的各个硬盘的真实安装位置,导致对硬盘IOPS性能进行检测的效率较低。
发明内容
本发明实施例提供了一种检测硬盘IOPS性能的方法及装置,能够提高对硬盘IOPS性能进行检测的效率。
本发明实施例提供了检测硬盘IOPS性能的方法,应用于Linux系统,包括:
确定计算机中需要进行IOPS性能检测的至少一个目标硬盘,并设定对各个所述目标硬盘进行访问的访问形式;
根据所述访问形式,依次对各个所述目标硬盘进行读操作或写操作;
对所述读操作或写操作过程进行监控,形成对应的记录文件;
根据所述记录文件,获取各个所述目标硬盘对应的IOPS数据。
优选地,
所述访问形式包括:256K顺序读形式、256K顺序写形式、4K随机读形式及4K随机写形式中的任意一个或多个。
优选地,
所述根据所述访问形式,依次对各个所述目标硬盘进行读操作或写操作包括以下四种操作中的任意一种或多种:
根据所述256K顺序读形式,依次对各个所述目标硬盘进行256K顺序读操作;
根据所述256K顺序写形式,依次对各个所述目标硬盘进行256K顺序写操作;
根据所述4K随机读形式,依次对各个所述目标硬盘进行4K随机读操作;
根据所述4K随机写形式,依次对各个所述目标硬盘进行4K随机写操作。
优选地,
所述Linux系统包括:x86架构的红帽操作系统或x86架构的社区企业Centos操作系统。
优选地,该方法进一步包括:
根据所述记录文件,获取各个所述目标硬盘对应的带宽和/或带宽利用率。
优选地,在所述根据所述记录文件,获取各个所述目标硬盘对应的IOPS数据之后进一步包括:
分别抓取各个所述目标硬盘的自检日志,根据所述自检日志获取对应目标硬盘的状态信息。
本发明实施例还提供了一种检测硬盘IOPS性能的装置,应用于Linux系统,包括:设定单元、检测单元、监控单元及提取单元;
所述设定单元,用于确定计算机中需要进行IOPS性能检测的至少一个目标硬盘,并设定对各个所述目标硬盘进行访问的访问形式;
所述检测单元,用于根据所述设定单元设定的访问形式,依次对所述设定单元确定的各个所述目标硬盘进行读操作或写操作;
所述监控单元,用于对所述检测单元进行的读操作或写操作过程进行监控,形成对应的记录文件;
所述提取单元,用于根据所述监控单元形成的记录文件,获取各个所述目标硬盘对应的IOPS数据。
优选地,
当所述设定单元设定的访问形式包括256K顺序读形式、256K顺序写形式、4K随机读形式及4K随机写形式中的任意一个或多个时,
所述检测单元,用于执行如下四种操作中的任意一种或多种:
根据所述256K顺序读形式,依次对各个所述目标硬盘进行256K顺序读操作;
根据所述256K顺序写形式,依次对各个所述目标硬盘进行256K顺序写操作;
根据所述4K随机读形式,依次对各个所述目标硬盘进行4K随机读操作;
根据所述4K随机写形式,依次对各个所述目标硬盘进行4K随机写操作。
优选地,
所述提取单元,进一步用于根据所述记录文件,获取各个所述目标硬盘对应的带宽和/或带宽利用率。
优选地,该装置进一步包括:抓取单元;
所述抓取单元,用于分别抓取各个所述目标硬盘的自检日志,根据所述自检日志获取对应目标硬盘的状态信息。
本发明实施例提供了一种检测硬盘IOPS性能的方法及装置,确定需要进行检测的目标硬盘后,设定对目标硬盘进行访问的访问形式,根据访问形式分别对各个目标硬盘进行访问,从各个硬盘中读取数据或写入数据,并对访问过程进行监控,形成对应的记录文件,从记录文件中获取各个目标硬盘对应的IOPS数据。该方法在Linux系统上进行,分别对各个目标硬盘进行测定,直接获取到各个目标硬盘的IOPS数据,不会出现硬盘与IOPS数据不对应的情况,因而无需通过热插拔硬盘的方式确定硬盘与IOPS数据的对应关系,从而提高了对硬盘IOPS性能进行检测的效率。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本发明一个实施例提供的一种检测硬盘IOPS性能的方法流程图;
图2是本发明一个实施例提供的一种检测硬盘IOPS性能的装置示意图;
图3是本发明另一个实施例提供的一种检测硬盘IOPS性能的方法流程图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例,基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。
如图1所示,本发明实施例提供了一种检测硬盘IOPS性能的方法,应用于Linux系统,该方法可以包括以下步骤:
步骤101:确定计算机中需要进行IOPS性能检测的至少一个目标硬盘,并设定对各个所述目标硬盘进行访问的访问形式;
步骤102:根据所述访问形式,依次对各个所述目标硬盘进行读操作或写操作;
步骤103:对所述读操作或写操作进行监控,形成对应的记录文件;
步骤104:根据所述记录文件,获取各个所述目标硬盘的IOPS数据。
本发明实施例提供了一种检测硬盘IOPS性能的方法,确定需要进行检测的目标硬盘后,设定对目标硬盘进行访问的访问形式,根据访问形式分别对各个目标硬盘进行访问,从各个硬盘中读取数据或写入数据,并对访问过程进行监控,形成对应的记录文件,从记录文件中获取各个目标硬盘对应的IOPS数据。该方法在Linux系统上进行,分别对各个目标硬盘进行测定,直接获取到各个目标硬盘的IOPS数据,不会出现硬盘与IOPS数据不对应的情况,因而无需通过热插拔硬盘的方式确定硬盘与IOPS数据的对应关系,从而提高了对硬盘IOPS性能进行检测的效率。
在本发明一个实施例中,对硬盘进行访问的访问形式包括256K顺序读形式、256K顺序写形式、4K随机读形式及4K随机写形式,在对硬盘进行检测时,可以根据用户的需求选择其中的一个或多个访问形式对硬盘进行测试,提高了该检测硬盘IOPS性能的方法的适用性及检测的全面性。
在本发明一个实施例中,当访问形式包括多种读访问形式或写访问形式时,依次针对于每一种访问形式,根据该访问形式依次对各个目标硬盘进行对应的读操作或写操作,直至对各个硬盘根据所有访问形式均进行了检测。这样,实现了通过不同的读写模式及每次读写数据量的大小对硬盘的IOPS性能进行检测,提高了检测的准确性。
在本发明一个实施例中,可以在x86架构的红帽操作系统或x86架构的社区企业Centos操作系统上实现该检测硬盘IOPS性能的方法,一方面避免了在Windows系统上出现硬盘与IOPS数据不对应的情况,提高对硬盘IOPS性能检测的准确性,另一方面可以实际情况选择红帽操作系统或Centos操作系统,进一步提高了该检测硬盘IOPS性能的方法的适用性。
在本发明一个实施例中,根据记录文件还能够获取目标硬盘在检测过程中的带宽及带宽利用率,根据检测需求可以选择是否获取这两个参数或者只获取其中的一个。这样,在获取硬盘的IOPS数据的同时还能够获取硬盘的带宽及带宽利用率,提高了对硬盘性能进行检测的全面性。
在本发明一个实施例中,在对目标硬盘检测结束后,还可以进一步抓取目标硬盘的自检日志,根据自检日志可以获取目标硬盘的状态信息,进而判断硬盘在检测过程中是否发生了损坏,进一步提高了检测的全面性。另外,在Linux系统上可以直接抓取硬盘的自检日志,相对于现有技术在Windows系统上检测,而在Linux系统抓取自检日志,提高了对硬盘性能进行检测的效率。
本发明提供了一种检测硬盘IOPS性能的装置,该装置可以通过软件实现,如图2所示,作为一个逻辑意义上的装置,是通过其所在设备的CPU将非易失性存储器中对应的计算机程序指令读取到内存中运行形成的。本实施例提供的检测硬盘IOPS性能的装置,包括:设定单元201、检测单元202、监控单元203及提取单元204;
所述设定单元201,用于确定计算机中需要进行IOPS性能检测的至少一个目标硬盘,并设定对各个所述目标硬盘进行访问的访问形式;
所述检测单元202,用于根据所述设定单元201设定的访问形式,依次对所述设定单元201确定的各个所述目标硬盘进行读操作或写操作;
所述监控单元203,用于对所述检测单元202进行的读操作或写操作过程进行监控,形成对应的记录文件;
所述提取单元204,用于根据所述监控单元203形成的记录文件,获取各个所述目标硬盘对应的IOPS数据。
本发明实施例提供了一种检测硬盘IOPS性能的装置,在Linux系统下,设定单元确定需要进行检测的目标硬盘以及对硬盘进行访问的访问形式后,检测单元根据设定的访问形式依次对各个目标硬盘进行读操作或写操作,监控单元对检测单元的检测过程进行监控,形成记录文件,提取单元从记录文件中获取目标硬盘的IOPS数据。检测单元依次对各个目标硬盘进行检测,形成对应的记录文件,在Linux系统下不会出现获取的IOPS数据与硬盘不对应的情况,无需通过热插拔硬盘来确定获取到的IOPS数据与硬盘的对应关系,从而提高了对硬盘IOPS性能进行检测的效率。
在本发明一个实施例中,设定单元可以将访问形式设置为256K顺序读形式、256K顺序写形式、4K随机读形式及4K随机写形式中的任意一个或多个,检测单元根据设定单元设定的各个读访问形式或写访问形式,依次针对于每一个访问形式,根据该访问形式依次对各个目标硬盘进行相应的读操作或写操作。实现了通过不同的访问形式对目标硬盘进行检测,提高了检测的全面性及检测结果的准确性。
在本发明一个实施例中,提取单元还可以从记录文件中获取各个目标硬盘的带宽及带宽利用率,或则两者中的任意一个,这样在获取目标硬盘的IOPS数据的同时还能够获取硬盘的带宽及带宽利用率,实现多种硬盘指标的同时检测,提高了对硬盘进行检测的效率。
在本发明一个实施例中,该装置进一步还可以包括抓取单元,在提取单元从记录文件中获取硬盘的IOPS数据等指标参数后,抓取单元对各个目标硬盘的自检日志进行抓取,从自检日志中可以获取对应目标硬盘的状态信息,根据状态信息进一步可以判断硬盘是否有损坏,从而在对硬盘进行开机无包装振动测试时,可以判断振动是否对硬盘造成了损坏,提高了对硬盘进行检测的全面性。
上述装置内的各单元之间的信息交互、执行过程等内容,由于与本发明方法实施例基于同一构思,具体内容可参见本发明方法实施例中的叙述,此处不再赘述。
为使本发明的目的、技术方案和优点更加清楚,下面结合图2所示的检测硬盘IOPS性能的装置,以对硬盘进行开机无包装振动检测为例,对本发明实施例提供的检测硬盘IOPS性能的方法作进一步地详细描述。
如图3所示,本发明实施例提供了一种检测硬盘IOPS性能的方法,该方法可以包括以下步骤:
步骤301:确定计算机中需要进行检测的目标硬盘。
在本发明一个实施例中,应用户的要求对计算机的硬盘进行开机无包装振动检测时,根据用户的要求,将计算机中的至少一个硬盘确定为目标硬盘。例如,一台服务器A共包括7个硬盘,分别为硬盘a、硬盘b、硬盘c、硬盘d、硬盘e、硬盘f及硬盘g,其中硬盘a为系统盘,用户要求对该服务器A中的非系统盘进行开机无包装振动检测,则将硬盘b至硬盘g确定为目标硬盘。
步骤302:确定对目标硬盘进行访问的访问形式。
在本发明一个实施例中,根据用户提出的检测要求,确定在对各个目标硬盘进行检测时采用的访问形式。例如,根据用户对服务器A的硬盘提出的检测要求,确定256K顺序读形式、256K顺序写形式、4K随机读形式及4K随机写形式作为对硬盘b至硬盘g进行检测时采用的访问形式。其中,256K顺序读形式为以每次256K大小的数据块依次从目标硬盘的各个扇区中读取数据,256K顺序写形式为以每次256K大小的数据块依次向目标硬盘的各个扇区中写入数据,4K随机读形式为以每次4K大小的数据块随机从目标硬盘的各个扇区中读取数据,4K随机写形式为以每次4K大小的数据块随机向目标硬盘的各个扇区中写入数据。
步骤303:根据每一种访问形式,依次对各个目标硬盘进行检测,监控检测过程,形成对应的记录文件。
在本发明一个实施例中,在确定目标硬盘及访问形式后,将计算机放置在振动台上,计算机在振动台的作用下产生振动,模拟硬盘在实际使用过程中的受力情况。在振动过程中,根据步骤302中设定的各个访问形式,依次针对于每一种访问形式,根据该访问形式依次对各个目标硬盘进行读操作或写操作,形成针对于每一种访问形式及每一个目标硬盘的记录文件。
例如,检测单元执行选定程序fio-test.sh,依次选定对目标硬盘进行测试的访问形式,其中选定程序fio-test.sh如下:
#!/bin/bash
./randread-4k.sh
sleep 100
./randwrite-4k.sh
sleep 100
./read-256k.sh
sleep 100
./write-256k.sh
exit
通过执行上述fio-test.sh程序,检测单元依次选定4K随机读形式、4K随机写形式、256K顺序读形式及256K顺序写形式对6个目标硬盘进行测试;
在检测单元选定一种访问形式后,执行该访问形式对应的检测程序,依次对6个目标硬盘进行检测,其中,4K随机写形式对应的检测程序为randwrite-4k.sh,4K随机读形式对应的检测程序为randread-4k.sh,256K顺序读形式对应的检测程序为read-256k.sh,256K顺序写形式对应的检测程序为write-256k.sh,其中,
检测程序randwrite-4k.sh如下:
检测程序randread-4k.sh如下:
检测程序read-256k.sh如下:
检测程序write-256k.sh如下:
上述各个检测程序中包括监控代码,监控单元通过执行监控代码对检测过程进行监控,形成每一个目标硬盘对应于每一个访问形式的记录文件,其中,
在4K随机读形式下6个目标硬盘的记录文件为randwrite4k$i.txt;
在4K随机写形式下6个目标硬盘的记录文件为randread4k$i.txt;
在256K顺序读形式下6个目标硬盘的记录文件为write256k$i.txt;
在256K顺序写形式下6个目标硬盘的记录文件为write256k$i.txt;
其中,i为目标硬盘的标识,对应于硬盘b至硬盘g时,i对应为b至g。
这样,每个最终得到每个目标硬盘对应的4个记录文件,共获得24个记录文件。
步骤304:根据记录文件,获取目标硬盘的IOPS数据、带宽及带宽利用率。
在本发明一个实施例中,在获取到在不同访问形式下对各个目标硬盘进行测试的记录文件后,从记录文件中提取对应目标硬盘在对应访问形式下的IOPS数据、带宽及带宽利用率。
例如,根据不同的访问形式,提取单元执行相对应的提取程序,从记录文件中提取出目标硬盘的IOPS数据、带宽及带宽利用率,各种访问形式对应的提取程序如下:
4K随机写形式对应的提取程序为:
done
sleep 360
for i in{b..g}
do
BW=`cat randwrite4k$i.txt|grep iops=|cut-d','-f 2|grep-oE"[0-9.]+"`
BWU=`cat randwrite4k$i.txt|grep iops=|cut-d','-f 2|cut-d'='-f 2|seds'/[0-9.]//'g`
IOPS=`cat randwrite4k$i.txt|grep iops=|cut-d','-f 3|cut-d'='-f 2`
echo"sd${i}_randwrite4k,$BW,$BWU,$IOPS">>randwrite4k-result.csv
done
echo"test complete!"
exit
4K随机读形式对应的提取程序为:
done
sleep 360
for i in{b..g}
do
BW=`cat randread4k$i.txt|grep iops=|cut-d','-f 2|grep-oE"[0-9.]+"`
BWU=`cat randread4k$i.txt|grep iops=|cut-d','-f 2|cut-d'='-f 2|seds'/[0-9.]//'g`
IOPS=`cat randread4k$i.txt|grep iops=|cut-d','-f 3|cut-d'='-f 2`
echo"sd${i}_randread4k,$BW,$BWU,$IOPS">>randread4k-result.csv
done
echo"test complete!"
exit
256K顺序读形式对应的提取程序为:
done
sleep 360
for i in{b..g}
do
BW=`cat read256k$i.txt|grep iops=|cut-d','-f 2|grep-oE"[0-9.]+"`
BWU=`cat read256k$i.txt|grep iops=|cut-d','-f 2|cut-d'='-f 2|seds'/[0-9.]//'g`
IOPS=`cat read256k$i.txt|grep iops=|cut-d','-f 3|cut-d'='-f 2`
echo"sd${i}_read256k,$BW,$BWU,$IOPS">>read256k-result.csv
done
echo"test complete!"
exit
256K顺序写形式对应的提取程序为:
done
sleep 360
for i in{b..g}
do
BW=`cat write256k$i.txt|grep iops=|cut-d','-f 2|grep-oE"[0-9.]+"`
BWU=`cat write256k$i.txt|grep iops=|cut-d','-f 2|cut-d'='-f 2|seds'/[0-9.]//'g`
IOPS=`cat write256k$i.txt|grep iops=|cut-d','-f 3|cut-d'='-f 2`
echo"sd${i}_write256k,$BW,$BWU,$IOPS">>write256k-result.csv
done
echo"test complete!"
exit
提取单元通过执行对应的上述提取程序,对监控单元获得的24个记录文件进行提取,从中获得各个目标硬盘在对应访问形式下的IOPS数据(IOPS)、带宽(BW)及带宽利用率(BWU),并存储到对应的检测结果文件中,共获得24个检测结果文件。
步骤305:对各个目标硬盘的自检目录进行抓取,获取各个目标硬盘的状态信息。
在本发明一个实施例中,在Linux系统上完成步骤301至步骤304的检测过程后,抓取单元分别对各个目标硬盘的自检日志进行抓取,根据自检日志获取各个目标硬盘的状态信息。例如,抓取单元分别对硬盘a至硬盘g的Smart日志进行抓取,从各个硬盘对应的Smart日志中获得该硬盘的状态信息。
步骤306:根据目标硬盘的IOPS数据、带宽、带宽利用率及状态信息,判断硬盘是否合格。
在本发明一个实施例中,在获取到在不同访问形式下各个目标硬盘的IOPS数据、带宽及带宽利用率后,该获取到的数据与用户提供的要求值进行比较,判断检测数据是否满足用户的要求;将步骤305中获取的目标硬盘的状态信息检测之前获得的目标硬盘的状态信息进行比较,判断目标硬盘在检测过程中是否出现损坏,如果各项检测数据均满足用户的要求,且硬盘在检测过程中没有被损坏,则判断硬盘的开机无包装振动性能合格。
需要说明的是,为了更加清楚的对本发明实施例提供的检测硬盘IOPS性能的方法进行说明,图3所示,将该检测硬盘IOPS性能的方法划分为多个步骤,在实际业务实现过程中,执行各个步骤之间没有严格的先后顺序。例如步骤304中的提取程序可以集成在步骤303中的检测程序中,此时检测程序如下:
对应于4K随机写形式的检测程序randwrite-4k.sh为:
对应于4K随机读形式的检测程序randread-4k.sh为:
对应于256K顺序读形式的检测程序read-256k.sh为:
对应于256K顺序写形式的检测程序write-256k.sh为:
本发明实施例提供的检测硬盘IOPS性能的方法及装置,至少具有如下有益效果:
1、本发明实施例中,确定需要进行检测的目标硬盘后,设定对目标硬盘进行访问的访问形式,根据访问形式分别对各个目标硬盘进行访问,从各个硬盘中读取数据或写入数据,并对访问过程进行监控,形成对应的记录文件,从记录文件中获取各个目标硬盘对应的IOPS数据。该方法在Linux系统上进行,分别对各个目标硬盘进行测定,直接获取到各个目标硬盘的IOPS数据,不会出现硬盘与IOPS数据不对应的情况,因而无需通过热插拔硬盘的方式确定硬盘与IOPS数据的对应关系,从而提高了对硬盘IOPS性能进行检测的效率。
2、本发明实施例中,获取硬盘IOPS数据的同时还能够获取硬盘的带宽及带宽利用率,无需单独对硬盘的带宽和带宽利用率进行检测,提高了对硬件性能进行检测的全面性及检测效率。
3、在本发明实施例中,该检测硬盘IOPS性能的方法在Linux系统上完成,在Linux系统上可以直接对硬盘的自检日志进行抓取,以获得硬盘的状态信息,抓取硬盘自检日志时无需切换操作系统,节省了切换操作系统的时间,进一步提高了对硬盘进行测试的效率。
4、本发明实施例中,在对硬盘的IOPS性能进行检测是,可以采用多种不同的访问形式对硬盘进行读操作或写操作,从而获取在不同的访问形式下硬盘的IOPS数据,这样可以模拟在真实使用过程中,以不同数据块大小及读写形式对硬盘进行的读操作或写操作,使检测条件更加贴近实际使用环境,提高了对硬盘IOPS性能检测的准确性。
需要说明的是,在本文中,诸如第一和第二之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个〃·····”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同因素。
本领域普通技术人员可以理解:实现上述方法实施例的全部或部分步骤可以通过程序指令相关的硬件来完成,前述的程序可以存储在计算机可读取的存储介质中,该程序在执行时,执行包括上述方法实施例的步骤;而前述的存储介质包括:ROM、RAM、磁碟或者光盘等各种可以存储程序代码的介质中。
最后需要说明的是:以上所述仅为本发明的较佳实施例,仅用于说明本发明的技术方案,并非用于限定本发明的保护范围。凡在本发明的精神和原则之内所做的任何修改、等同替换、改进等,均包含在本发明的保护范围内。

Claims (10)

1.一种检测硬盘IOPS性能的方法,其特征在于,应用于Linux系统,包括:
确定计算机中需要进行IOPS性能检测的至少一个目标硬盘,并设定对各个所述目标硬盘进行访问的访问形式;
根据所述访问形式,依次对各个所述目标硬盘进行读操作或写操作;
对所述读操作或写操作过程进行监控,形成对应的记录文件;
根据所述记录文件,获取各个所述目标硬盘对应的IOPS数据。
2.根据权利要求1所述的方法,其特征在于,
所述访问形式包括:256K顺序读形式、256K顺序写形式、4K随机读形式及4K随机写形式中的任意一个或多个。
3.根据权利要求2所述的方法,其特征在于,
所述根据所述访问形式,依次对各个所述目标硬盘进行读操作或写操作包括:
根据所述256K顺序读形式,依次对各个所述目标硬盘进行256K顺序读操作;
和/或,
根据所述256K顺序写形式,依次对各个所述目标硬盘进行256K顺序写操作;
和/或,
根据所述4K随机读形式,依次对各个所述目标硬盘进行4K随机读操作;
和/或,
根据所述4K随机写形式,依次对各个所述目标硬盘进行4K随机写操作。
4.根据权利要求1所述的方法,其特征在于,
所述Linux系统包括:x86架构的红帽操作系统或x86架构的社区企业Centos操作系统。
5.根据权利要求1所述的方法,其特征在于,进一步包括:
根据所述记录文件,获取各个所述目标硬盘对应的带宽和/或带宽利用率。
6.根据权利要求1至5中任一所述的方法,其特征在于,
在所述根据所述记录文件,获取各个所述目标硬盘对应的IOPS数据之后进一步包括:
分别抓取各个所述目标硬盘的自检日志,根据所述自检日志获取对应目标硬盘的状态信息。
7.一种检测硬盘IOPS性能的方法,其特征在于,应用于Linux系统,包括:设定单元、检测单元、监控单元及提取单元;
所述设定单元,用于确定计算机中需要进行IOPS性能检测的至少一个目标硬盘,并设定对各个所述目标硬盘进行访问的访问形式;
所述检测单元,用于根据所述设定单元设定的访问形式,依次对所述设定单元确定的各个所述目标硬盘进行读操作或写操作;
所述监控单元,用于对所述检测单元进行的读操作或写操作过程进行监控,形成对应的记录文件;
所述提取单元,用于根据所述监控单元形成的记录文件,获取各个所述目标硬盘对应的IOPS数据。
8.根据权利要求7所述的装置,其特征在于,当所述设定单元设定的访问形式包括256K顺序读形式、256K顺序写形式、4K随机读形式及4K随机写形式中的任意一个或多个时,
所述检测单元,用于根据所述256K顺序读形式,依次对各个所述目标硬盘进行256K顺序读操作;
和/或,
所述检测单元,用于根据所述256K顺序写形式,依次对各个所述目标硬盘进行256K顺序写操作;
和/或
所述检测单元,用于根据所述4K随机读形式,依次对各个所述目标硬盘进行4K随机读操作;
和/或,
所述检测单元,用于根据所述4K随机写形式,依次对各个所述目标硬盘进行4K随机写操作。
9.根据权利要求7所述的装置,其特征在于,
所述提取单元,进一步用于根据所述记录文件,获取各个所述目标硬盘对应的带宽和/或带宽利用率。
10.根据权利要求7至9中任一所述的装置,其特征在于,进一步包括:抓取单元;
所述抓取单元,用于分别抓取各个所述目标硬盘的自检日志,根据所述自检日志获取对应目标硬盘的状态信息。
CN201610204390.3A 2016-04-05 2016-04-05 一种检测硬盘iops性能的方法及装置 Pending CN105893230A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201610204390.3A CN105893230A (zh) 2016-04-05 2016-04-05 一种检测硬盘iops性能的方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201610204390.3A CN105893230A (zh) 2016-04-05 2016-04-05 一种检测硬盘iops性能的方法及装置

Publications (1)

Publication Number Publication Date
CN105893230A true CN105893230A (zh) 2016-08-24

Family

ID=57013333

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201610204390.3A Pending CN105893230A (zh) 2016-04-05 2016-04-05 一种检测硬盘iops性能的方法及装置

Country Status (1)

Country Link
CN (1) CN105893230A (zh)

Cited By (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106844119A (zh) * 2017-01-25 2017-06-13 郑州云海信息技术有限公司 一种设备的检测方法、装置和系统
CN107358980A (zh) * 2017-07-19 2017-11-17 郑州云海信息技术有限公司 一种自动化测试ssd延时的方法
CN107506270A (zh) * 2017-08-24 2017-12-22 郑州云海信息技术有限公司 一种测试ssd一致性的方法
CN107544759A (zh) * 2017-09-19 2018-01-05 郑州云海信息技术有限公司 一种磁盘阵列io分配系统及方法
CN107885628A (zh) * 2017-11-13 2018-04-06 郑州云海信息技术有限公司 一种磁盘i/o性能的测试方法、装置及设备
CN108038031A (zh) * 2017-12-07 2018-05-15 郑州云海信息技术有限公司 一种实时监控硬盘在线状态的方法及装置
CN109324937A (zh) * 2018-09-18 2019-02-12 郑州云海信息技术有限公司 一种测试ssd稳态的方法、装置、设备以及存储介质
CN109684137A (zh) * 2017-10-19 2019-04-26 航天信息股份有限公司 一种用于对目标设备进行检测的方法及系统
CN112363901A (zh) * 2020-11-17 2021-02-12 浙江大华技术股份有限公司 硬盘性能检测方法、装置、系统、存储介质及电子装置
CN112650635A (zh) * 2020-12-22 2021-04-13 宁畅信息产业(北京)有限公司 硬盘性能测试方法及模拟硬盘

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101872320A (zh) * 2010-04-16 2010-10-27 浪潮电子信息产业股份有限公司 一种关于ssd硬盘可靠性及性能的测试及统计方法
CN102411993A (zh) * 2011-11-24 2012-04-11 曙光信息产业股份有限公司 固态硬盘的测试方法和装置
CN102999504A (zh) * 2011-09-13 2013-03-27 鸿富锦精密工业(深圳)有限公司 硬盘测试数据分析方法
CN103578568A (zh) * 2012-07-24 2014-02-12 苏州捷泰科信息技术有限公司 固态硬盘的性能测试方法及装置
CN103699474A (zh) * 2012-09-27 2014-04-02 鸿富锦精密工业(深圳)有限公司 存储设备监控系统及方法

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101872320A (zh) * 2010-04-16 2010-10-27 浪潮电子信息产业股份有限公司 一种关于ssd硬盘可靠性及性能的测试及统计方法
CN102999504A (zh) * 2011-09-13 2013-03-27 鸿富锦精密工业(深圳)有限公司 硬盘测试数据分析方法
CN102411993A (zh) * 2011-11-24 2012-04-11 曙光信息产业股份有限公司 固态硬盘的测试方法和装置
CN103578568A (zh) * 2012-07-24 2014-02-12 苏州捷泰科信息技术有限公司 固态硬盘的性能测试方法及装置
CN103699474A (zh) * 2012-09-27 2014-04-02 鸿富锦精密工业(深圳)有限公司 存储设备监控系统及方法

Cited By (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106844119A (zh) * 2017-01-25 2017-06-13 郑州云海信息技术有限公司 一种设备的检测方法、装置和系统
CN107358980A (zh) * 2017-07-19 2017-11-17 郑州云海信息技术有限公司 一种自动化测试ssd延时的方法
CN107506270A (zh) * 2017-08-24 2017-12-22 郑州云海信息技术有限公司 一种测试ssd一致性的方法
CN107544759B (zh) * 2017-09-19 2021-01-29 苏州浪潮智能科技有限公司 一种磁盘阵列io分配系统及方法
CN107544759A (zh) * 2017-09-19 2018-01-05 郑州云海信息技术有限公司 一种磁盘阵列io分配系统及方法
CN109684137A (zh) * 2017-10-19 2019-04-26 航天信息股份有限公司 一种用于对目标设备进行检测的方法及系统
CN107885628A (zh) * 2017-11-13 2018-04-06 郑州云海信息技术有限公司 一种磁盘i/o性能的测试方法、装置及设备
CN108038031A (zh) * 2017-12-07 2018-05-15 郑州云海信息技术有限公司 一种实时监控硬盘在线状态的方法及装置
CN109324937A (zh) * 2018-09-18 2019-02-12 郑州云海信息技术有限公司 一种测试ssd稳态的方法、装置、设备以及存储介质
CN112363901A (zh) * 2020-11-17 2021-02-12 浙江大华技术股份有限公司 硬盘性能检测方法、装置、系统、存储介质及电子装置
CN112363901B (zh) * 2020-11-17 2023-08-29 浙江大华技术股份有限公司 硬盘性能检测方法、装置、系统、存储介质及电子装置
CN112650635A (zh) * 2020-12-22 2021-04-13 宁畅信息产业(北京)有限公司 硬盘性能测试方法及模拟硬盘
CN112650635B (zh) * 2020-12-22 2024-01-30 宁畅信息产业(北京)有限公司 硬盘性能测试方法及模拟硬盘

Similar Documents

Publication Publication Date Title
CN105893230A (zh) 一种检测硬盘iops性能的方法及装置
CN102568522B (zh) 硬盘性能的测试方法和装置
CN111756575B (zh) 存储服务器的性能分析方法及装置、电子设备
CN110502374A (zh) 识别自动测试时设备故障的根本原因的流量捕获调试工具
CN107480039A (zh) 一种分布式存储系统的小文件读写性能测试方法及装置
CN105068936B (zh) 一种软件的稳定性的测试方法及装置
CN103744759A (zh) 一种Linux系统下无人值守磁盘性能及稳定性验证方法
CN106649092A (zh) 一种测试脚本生成方法、网页测试方法、装置和系统
CN106021045A (zh) 一种linux系统下服务器硬盘IO性能的测试方法
CN110008129A (zh) 一种存储定时快照的可靠性测试方法、装置及设备
CN109726130A (zh) Bmc事件日志策略的测试系统、方法、设备及存储介质
CN106649020A (zh) 一种存储器机箱烧录信息的检测方法及装置
CN112631848A (zh) 一种机械硬盘故障智能诊断方法及系统
CN108845908A (zh) 一种ssd硬盘测试方法、装置、设备及介质
CN107329914A (zh) 一种基于Linux系统检测硬盘乱序的方法及装置
TW434478B (en) Method for testing the integrity of software pre-installed in a computer hard disk
CN114518981A (zh) eMMC测试方法、装置、可读存储介质及电子设备
CN104615514A (zh) 一种对raid卡各raid级别性能检验方法
CN106201857A (zh) 测试用例的选取方法及装置
CN104063307A (zh) 一种软件测试方法和系统
CN106326046A (zh) 存储器控制器的验证环境平台
CN107515803A (zh) 一种存储性能测试方法和装置
CN113138916B (zh) 基于标注样本的图片结构化算法的自动测试方法及系统
CN117076337B (zh) 一种数据传输方法、装置、电子设备及可读存储介质
CN102999504A (zh) 硬盘测试数据分析方法

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
WD01 Invention patent application deemed withdrawn after publication
WD01 Invention patent application deemed withdrawn after publication

Application publication date: 20160824