linux中btt工具详解

简介:

  在之前的文章中介绍了如何使用blktrace 以及其工作原理和架构。我们知道blktrace 跟踪块设备的统计信息,每个CPU会有一个文件存储,然后通过blkparse可以将这些文件整合成一个文件来显示。

            不过blkparse显示的文件过于庞大,而通过btt分析后会发现监控数据变得更加有意义。

1.   示例

监控获得数据

#blktrace -d /dev/sda -o sdatest

合并多个文件

#blkparse -i sdatest -d sdatest.bin

#btt -i sdatest.bin

2.   输出简要信息

第一部分平均时间

IO时间主要是分为三个区域:

n   插入或合并IO到请求队列的时间,计算从块层到插入,即Q2I(Q2I=Q2G+G2I)

n   请求队列到驱动的时间,即是I2D。

n   驱动和设备时间,即是D2C.

此外还有还有Q2Q表示IO交到块层的时间。系统等待请求的时间在Q2G中。一般情况下Q2C=Q2I+I2D+D2C,说一般情况因为有些IO会会执行merge。

把大写字母函数的表,再次方便查找:

Act

Description

A

IO was remapped to a different device

B

IO bounced

C

IO completion

D

IO issued to driver

F

IO front merged with request on queue

G

Get request

I

IO inserted onto request queue

M

IO back merged with request on queue

P

Plug request

Q

IO handled by request queue code

S

Sleep request

T

Unplug due to timeout

U

Unplug request

X

Split

显示所有IO的平均时间,如下

==================== All Devices ====================

 

            ALL           MIN           AVG           MAX           N

--------------- ------------- ------------- ------------- -----------

 

Q2Q               0.000001946   0.091683105   2.044408235          23

Q2G               0.000000414   0.000033828   0.000674679          25

G2I               0.000000102   0.000144889   0.002673577          25

Q2M               0.000000182   0.000000856   0.000002371           4

I2D               0.000000470   0.004403646   0.005128490          16

M2D               0.000004614   0.003767183   0.005123517           4

D2C               0.000103260   0.003153379   0.043896995          20

Q2C               0.000105885   0.007446862   0.043903980          20

第二部分设备损耗

第一部分中得到设备的平均延时,第二部分得到各个阶段消耗比例得到定性分析,如下图:

==================== Device Overhead ====================

 

       DEV |       Q2G       G2I       Q2M       I2D       D2C

---------- | --------- --------- --------- --------- ---------

 (  8,  0) |   0.5678%   2.4320%   0.0023%  47.3074%  42.3451%

---------- | --------- --------- --------- --------- ---------

   Overall |   0.5678%   2.4320%   0.0023%  47.3074%  42.3451%

第三部分设备合并信息

==================== Device Merge Information ====================

 

       DEV |       #Q       #D   Ratio |   BLKmin   BLKavg   BLKmax    Total

---------- | -------- -------- ------- | -------- -------- -------- --------

 (  8,  0) |       25       25     1.0 |        1      672     2560    16808

            Q表示传入的IO请求,D表示合并后发出的请求,此外还能看到平均IO块大小为672。

第四部分磁盘寻道讯息

用于显示连续队列和提交IO之间的扇区距离。NSEEKS表示提交到驱动的IO寻道次数, MEAS表示IO之间距离,MEDIA为0表示向前和向后寻道次数一样,MODE中数值表示块IO中连续的扇区,这部分比较晦涩。

包含Q2Q和D2D两部分,Q2Q是到达的IO请求之间,D2D是驱动中处理的IO.请求

==================== Device Q2Q Seek Information ====================

 

       DEV |          NSEEKS            MEAN          MEDIAN | MODE          

---------- | --------------- --------------- --------------- | ---------------

 (  8,  0) |              24       5406419.2               0 | 0(8)

---------- | --------------- --------------- --------------- | ---------------

   Overall |          NSEEKS            MEAN          MEDIAN | MODE          

   Average |              24       5406419.2               0 | 0(8)

==================== Device D2D Seek Information ====================

       DEV |          NSEEKS            MEAN          MEDIAN | MODE          

---------- | --------------- --------------- --------------- | ---------------

 (  8,  0) |              25       5190101.0               0 | 0(9)

---------- | --------------- --------------- --------------- | ---------------

   Overall |          NSEEKS            MEAN          MEDIAN | MODE          

   Average |              25       5190101.0               0 | 0(9)

第五部分请求队列阻塞信息

队列不是无限的的,必然存在队列阻塞情况,这个就是现实队列阻塞,不能被驱动处理。这里的统计信息就是现实不能被处理的比例,如下图:

==================== Plug Information ====================

 

       DEV |    # Plugs # Timer Us  | % Time Q Plugged

---------- | ---------- ----------  | ----------------

 (  8,  0) |         12(         0) |   0.032358934%

 

       DEV |    IOs/Unp   IOs/Unp(to)

---------- | ----------   ----------

 (  8,  0) |        2.1          0.0

---------- | ----------   ----------

   Overall |    IOs/Unp   IOs/Unp(to)

   Average |        2.1          0.0

 

 

第六部分队列中IO调度

  有时候需要关注请求在IO调度上花费的时间。

       DEV |  Avg Reqs @ Q

---------- | -------------

 (  8,  0) |           4.4

详细数据

使用--all-data或-A可以显示更详细信息。

可以显示每个设备的在各个阶段的统计数据。

3.   活动数据文件

活动数据文件的格式容易被画图和分析,如下:

# Total System

#     Total System : q activity

  0.000000624   0.0

  0.000000624   0.4

  0.004054842   0.4

  0.004054842   0.0

  2.048463077   0.0

  2.048463077   0.4

  2.108712044   0.4

  2.108712044   0.0

  文件中数据是划分成对的,每对包含队列信息和完成信息。

 

 

 

 

目录
相关文章
|
4月前
|
Linux 网络安全 数据安全/隐私保护
Linux 超级强大的十六进制 dump 工具:XXD 命令,我教你应该如何使用!
在 Linux 系统中,xxd 命令是一个强大的十六进制 dump 工具,可以将文件或数据以十六进制和 ASCII 字符形式显示,帮助用户深入了解和分析数据。本文详细介绍了 xxd 命令的基本用法、高级功能及实际应用案例,包括查看文件内容、指定输出格式、写入文件、数据比较、数据提取、数据转换和数据加密解密等。通过掌握这些技巧,用户可以更高效地处理各种数据问题。
433 8
|
1月前
|
监控 安全 Ubuntu
Linux下如何安装配置Fail2ban防护工具
通过以上步骤,可以在Linux系统中成功安装和配置Fail2ban,从而有效保护服务器免受暴力破解等攻击。Fail2ban通过实时监控日志文件,自动更新防火墙规则,为系统安全提供了一层重要的保护。
135 36
|
2月前
|
Rust Ubuntu Java
[Linux工具] Makefile
Makefile是Linux环境下用于自动化编译和链接程序的配置文件,常用于简化大型项目的编译流程。通过定义目标文件、依赖文件及生成命令,Makefile能高效管理编译任务。它不仅适用于C语言项目,还可扩展到其他编程语言和非编程任务中。
63 20
[Linux工具] Makefile
|
24天前
|
Linux API
Linux下载工具wget与curl
`wget` 是一个用于从网络下载文件的命令行工具,支持HTTP、HTTPS和FTP协议。它能自动处理下载中断,并支持递归下载网站内容。基本用法:`wget URL`,可指定文件名(`-O`)、保存目录(`-P`),还支持断点续传(`-c`)、限速(`--limit-rate`)和递归下载(`-r`)。相比之下,`curl` 更侧重于发送各种HTTP请求(如GET、POST),并支持文件上传、自定义请求头和cookie等功能。
57 10
|
21天前
|
存储 Ubuntu 前端开发
Linux软件包管理工具概览
在Linux系统中,dpkg、apt、rpm、yum和dnf是几种常见的包管理工具,它们分别属于不同的Linux发行版或家族,并有着各自的诞生顺序和特点。下面将按照这些工具的诞生顺序,并结合Debian、Red Hat、CentOS、Ubuntu和Kali等系统,进行详细的介绍。
25 4
|
5月前
|
监控 Unix Linux
Linux系统工具
Linux系统工具
77 6
|
2月前
|
Linux 网络性能优化 网络安全
Linux(openwrt)下iptables+tc工具实现网络流量限速控制(QoS)
通过以上步骤,您可以在Linux(OpenWrt)系统中使用iptables和tc工具实现网络流量限速控制(QoS)。这种方法灵活且功能强大,可以帮助管理员有效管理网络带宽,确保关键业务的网络性能。希望本文能够为您提供有价值的参考。
152 28
|
2月前
|
网络协议 Unix Linux
深入解析:Linux网络配置工具ifconfig与ip命令的全面对比
虽然 `ifconfig`作为一个经典的网络配置工具,简单易用,但其功能已经不能满足现代网络配置的需求。相比之下,`ip`命令不仅功能全面,而且提供了一致且简洁的语法,适用于各种网络配置场景。因此,在实际使用中,推荐逐步过渡到 `ip`命令,以更好地适应现代网络管理需求。
61 11
|
2月前
|
安全 网络协议 Linux
结合 `nc` 工具利用笑脸漏洞(Smile Bug)攻击 Metasploitable2 Linux
本文介绍如何使用 `nc`(Netcat)工具结合笑脸漏洞(Smiley Bug)攻击 Metasploitable2 Linux 靶机。首先概述了 `nc` 的基本功能和高级用法,包括建立连接、监听端口、文件传输等操作。接着详细描述了笑脸漏洞的原理及其在网络攻防中的应用,展示了通过 `nc` 发送恶意输入检测漏洞的方法。最后结合 Python 脚本实现更复杂的攻击场景,并强调了合法性和环境隔离的重要性。
61 13
|
3月前
|
运维 监控 Linux
推荐几个不错的 Linux 服务器管理工具
推荐几个不错的 Linux 服务器管理工具
260 6