Alibaba Cloud Linux对IO时延分析工具iostat的原始数据来源/proc/diskstats
接口进行了优化,新增了对设备侧的读、写及特殊IO(discard)等耗时的统计。此外,Alibaba Cloud Linux 2系统还提供了一个便于追踪IO时延的工具bcc。本文将介绍Alibaba Cloud Linux 2系统优化后的/proc/diskstats
接口和bcc工具。
/proc/diskstats接口说明
/proc/diskstats接口在Alibaba Cloud Linux 2中可查询磁盘IO信息、设备侧的读耗时、设备侧的写耗时及设备侧discard耗时。
查询/proc/diskstats接口。
cat /proc/diskstats
返回结果示例如下。
254 0 vda 6328 3156 565378 2223 1610 424 25160 4366 0 1358 5332 0 0 0 0 2205 3347 0
返回结果中,最后三个域为Alibaba Cloud Linux 2新增域,域说明如下。
安装使用bcc工具
Alibaba Cloud Linux 2提供了一种便捷的工具bcc,以帮助用户追踪IO延迟。
执行以下命令,安装bcc工具。
yum install -y bcc-tools
您可以通过以下两种命令查看bcc工具的说明。
通过以下命令获取bcc工具说明。
/usr/share/bcc/tools/alibiolatency -h
工具说明如下。
usage: alibiolatency [-h] [-d DEVICE] [-i [DIS_INTERVAL]] [-t [AVG_THRESHOLD_TIME]] [-T [THRESHOLD_TIME]] [-r] Summarize block device I/O latency optional arguments: -h, --help show this help message and exit -d DEVICE, --device DEVICE inspect specified device -i [DIS_INTERVAL], --dis_interval [DIS_INTERVAL] specify display interval -t [AVG_THRESHOLD_TIME], --avg_threshold_time [AVG_THRESHOLD_TIME] display only when average request process time is greater than this value -T [THRESHOLD_TIME], --threshold_time [THRESHOLD_TIME] dump request life cycle when single request process time is greater than this value -r, --dump_raw dump every io request life cycle examples: ./alibiolatency # summarize block I/O latency(default display interval is 2s) ./alibiolatency -d sda3 # inspect specified device /dev/sda3 ./alibiolatency -i 2 # specify display interval, 2s ./alibiolatency -t 10 # display only when average request process time is greater than 10ms ./alibiolatency -T 20 # dump request life cycle when single request process time is greater than 20ms ./alibiolatency -r # dump every io request life cycle
通过
man
命令获取bcc工具说明。man bcc-alibiolatency