ディスクがシークしているかどうかを検出する方法は?


16

私は(のような、現在のシステムを通って流れるディスクI / Oの量を測定するためのさまざまなツールを使用することができますiotopし、iostat)それは、ディスクがほんの少量で多くのことを求めているならば、容易に検出することが可能だ場合、私は好奇心が強いですI / O。

私はそれを知っています;を使用blktraceしてこの情報を抽出し、それを使用してデコードすることは可能ですbttが、これらはやや扱いにくいものであり、より簡単な代替手段があることを望んでいましたか?


4
耳をドライブに近づけますか?:)
テルドン

2
低い比率(rkB/s + wkB/s)/%utilは、ディスクがシークしていることを示すものではありませんiostat -xか(で)?
マルコ

1
これをライブで表示するツールが必要ですか、それとも特定の期間のデータを見たいですか?
slm

1
知る限りでは、kernel.org / doc / Documentation / iostats.txt がカーネルによって維持される唯一の統計なので、blktraceよりも優れているとは思わないでしょう。
ステファンシャゼル

回答:


4

出力の比率(rkB/s + wkB/s)/%utilにより、iostat -x次のような洞察が得られます。

Device:  rrqm/s wrqm/s   r/s   w/s  rkB/s  wkB/s avgrq-sz avgqu-sz await r_await w_await  svctm  %util
sda        0.04   3.65  7.16  6.37 150.82 212.38    53.71     0.03  1.99    0.82    3.31   0.76   1.03

この比率がディスクシークにどの程度正確に対応しているかはわかりません。しかし、アイデアは、ディスクがビジーであり、高いスループットを持たない場合、おそらく探しているということです。ただし、保証されているわけではありません。破損したディスクは、使用率が高く、スループットがほとんどない場合があります。しかし、それは少なくとも指標です。

また、iostatに番号(例:)iostat -x 5を指定して、更新間隔を指定することもできます。そうすれば、継続的に監視できます。


おそらく、低RKBに対してペア多くの読み取り要求/ sがこのような状況の指標となります
Gearoidマーフィー

8

この種の情報をリアルタイムで表示するツールと一定期間にわたって表示するツールを探しているかどうかはわかりませんが、アクセスしているディスクのリアルタイムの側面を表示する2つのツールがあります。

nmon

そのように呼び出しnmonます。それが開いたら、j(Filesystems)に続いてd(Disk I / O Graphs D = Stats)を押します。詳細については、組み込みヘルプ(h)を参照してください。

$ nmon
┌nmon─13g─────────────────────Hostname=manny────────Refresh= 2secs ───11:15.32─────────────────────────────────────────────────────┐
│ Filesystems ─────────────────────────────────────────────────────────────────────────────────────────────────────────────────────│
│Filesystem            SizeMB  FreeMB %Used Type     MountPoint                                                                    │
│v/mapper/ubuntu-root 465389.0 457483.9   1.7 ext4     /                                                                           │
│/proc                                      proc     not a real filesystem                                                         │
│/sys                                       sysfs    not a real filesystem                                                         │
│/sys/fs/fuse/connections                   fusectl  not a real filesystem                                                         │
│/sys/kernel/debug                          debugfs  not mounted                                                                   │
│/sys/kernel/security                       security not a real filesystem                                                         │
│/dev                                       devtmpfs not a real filesystem                                                         │
│/dev/pts                                   devpts   not a real filesystem                                                         │
│tmpfs                  740.5   739.4   0.1 tmpfs    /run                                                                          │
│none                     5.0     5.0   0.0 tmpfs    /run/lock                                                                     │
│none                  1851.2  1849.8   0.1 tmpfs    /run/shm                                                                      │
│none                   100.0    99.9   0.1 tmpfs    /run/user                                                                     │
│/dev/sda1              910.9   606.5  33.4 ext2     /boot                                                                         │
│/run/rpc_pipefs                            rpc_pipe fstatfs returned zero blocks!!                                                │
│/run/user/emma/gvfs                        fuse.gvf not mounted                                                                   │
│/run/user/emily/gvfs                       fuse.gvf not mounted                                                                   │
│ Disk I/O ──/proc/diskstats────mostly in KB/s─────Warning:contains duplicates─────────────────────────────────────────────────────│
│DiskName Busy  Read WriteMB|0          |25         |50          |75       100|                                                    │
│sda      100%    0.0   66.4|RWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWW>                                                    │
│sda1       0%    0.0    0.0|>                                                |                                                    │
│sda2       0%    0.0    0.0|>                                                |                                                    │
│sda5     100%    0.0   66.4|RWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWW>                                                    │
│dm-0     100%    0.0   48.0|RWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWW>                                                    │
│dm-1       0%    0.0    0.0|                     >                           |                                                    │
│Totals Read-MB/s=0.0      Writes-MB/s=180.9    Transfers/sec=363.2                                                                │
│──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────│

私が出会ったもう1つのツールは、少なくともディスクI / Oのライブビューですatop

$ atop
ATOP - grinchy                           2013/08/23  11:10:58                           ------                           10s elapsed
PRC | sys    2.18s  | user  26.26s  | #proc    315  | #trun  5 |  #tslpi   764 |  #tslpu     1 |  #zombie    0 |  #exit  1 |
CPU | sys      22%  | user    264%  | irq       0%  | idle    110% |  wait      4% |  guest     0% |  curf 1.20GHz |  curscal  44% |
cpu | sys       5%  | user     76%  | irq       0%  | idle     19% |  cpu003 w  0% |  guest     0% |  curf 1.20GHz |  curscal  44% |
cpu | sys       5%  | user     67%  | irq       0%  | idle     26% |  cpu001 w  2% |  guest     0% |  curf 1.20GHz |  curscal  44% |
cpu | sys       5%  | user     62%  | irq       0%  | idle     31% |  cpu000 w  1% |  guest     0% |  curf 1.20GHz |  curscal  44% |
cpu | sys   7%  | user     58%  | irq   0%  | idle     34% |  cpu002 w  1% |  guest     0% |  curf 1.20GHz |  curscal  44% |
CPL | avg1    3.83  | avg5    4.59  | avg15   4.76  |              |  csw    54101 |  intr   45315 |               |  numcpu     4 |
MEM | tot     7.6G  | free  194.3M  | cache 495.5M  | dirty   2.7M |  buff   38.9M |  slab   86.7M |               |               |
SWP | tot     5.7G  | free    5.5G  |               |              |               |               |  vmcom  12.4G |  vmlim   9.5G |
LVM | nchy-lv_home  | busy     11%  | read       1  | write    524 |  KiB/w      3 |  MBr/s   0.00 |  MBw/s   0.20 |  avio 2.05 ms |
LVM | nchy-lv_root  | busy      1%  | read       0  | write      7 |  KiB/w  4 |  MBr/s   0.00 |  MBw/s   0.00 |  avio 9.00 ms |
DSK |          sda  | busy     11%  | read       1  | write    109 |  KiB/w 19 |  MBr/s   0.00 |  MBw/s   0.20 |  avio 10.3 ms |
NET | transport     | tcpi  72  | tcpo     118  | udpi      15 |  udpo   5 |  tcpao     11 |  tcppo      0 |  tcprs      0 |
NET | network       | ipi       87  | ipo      123  | ipfrw      0 |  deliv     87 |               |  icmpi      0 |  icmpo      0 |
NET | wlan0   ----  | pcki      88  | pcko     123  | si   34 Kbps |  so   19 Kbps |  erri       0 |  erro       0 |  drpo       0 |

  PID  RUID       EUID       THR    SYSCPU    USRCPU   VGROW    RGROW    RDDSK   WRDSK   ST   EXC  S   CPUNR    CPU  CMD         1/4
 3649  saml       saml        34     0.33s    11.98s      0K    1752K       4K   2828K   --     -  R       2   122%  chrome
10399  saml       saml         4     0.14s     3.08s   5120K   -12.8M       0K      0K   --     -  S       2    32%  chrome

具体的には、LVMおよびDSKアクティビティを示している次の行:

    LVM | nchy-lv_home  | busy     11%  | read       1  | write    524 |  KiB/w      3 |  MBr/s   0.00 |  MBw/s   0.20 |  avio 2.05 ms |
    LVM | nchy-lv_root  | busy      1%  | read       0  | write      7 |  KiB/w  4 |  MBr/s   0.00 |  MBw/s   0.00 |  avio 9.00 ms |
    DSK |          sda  | busy     11%  | read       1  | write    109 |  KiB/w 19 |  MBr/s   0.00 |  MBw/s   0.20 |  avio 10.3 ms |

iostat

一定期間のデータに興味がある場合は、iostatおそらくスクリプトにラップされた最良のオプションです。処理を簡単にするために、使用率の出力を取り除くことができます。

$ iostat -dx /dev/sda 5
Linux 2.6.35.14-106.fc14.x86_64 (grinchy)   08/23/2013  _x86_64_    (4 CPU)

Device:         rrqm/s   wrqm/s     r/s     w/s   rsec/s   wsec/s avgrq-sz avgqu-sz   await  svctm  %util
sda               1.82    96.60    3.84   20.68   122.26   891.99    41.36     0.46   18.77   7.35  18.01

Device:         rrqm/s   wrqm/s     r/s     w/s   rsec/s   wsec/s avgrq-sz avgqu-sz   await  svctm  %util
sda               0.00    26.20    1.60   24.60    17.60   350.40    14.05     0.31   11.95   8.84  23.16

カーネルから直接

このコードブロック(bash)は、カーネルから直接処理された読み取りI / Oを表示します。

OLD=`awk '{print $1}' /sys/block/sda/stat` # First field is number of read I/Os processed
DT=1
for ii in `seq 1 10`
do
    sleep $DT
    NEW=`awk '{print $1}' /sys/block/sda/stat`
    echo $((($NEW-$OLD)/$DT))
    OLD=$NEW
done

ソース:https : //serverfault.com/a/525248/2518

情報は、いずれかから持っていたことができる/sys/block/sda/statか、/proc/diskstatsあなたがまたは任意のツールをインストールしたくないことはできない状況で。

参照資料


詳細な回答に感謝しますが、提供されたメトリックはまだI / Oに焦点が当てられています。理想的には、I / Oスループットに関係なくディスクシークアクティビティを見たいと思います
Gearoid Murphy

@GearoidMurphy-I / O外のディスクアクセスに関するこの種のテレメトリデータを取得する方法が見つかりませんでした。
slm

上記のコメントでマルコがヒットしたと思います。解決策は、ディスクトランザクションの実際の読み取り/書き込みデータ量に対する比率を調べることです。
ギアロイドマーフィー

1
@GearoidMurphy-ええ、だからこそ、リアルタイムタイプのソリューションと期間タイプのどちらが必要かについて、コメントで明確化を求めました。あなたが実行可能な解決策を思いついた場合、私は答えとしてそれを書き、それを受け入れます。これに関する特定の傾斜を検索するとき、多くはありませんでした。
slm
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.