4.2. ディスク
以下のセクションでは、ディスクおよび I/O アクティビティーを監視するスクリプトを説明します。
4.2.1. ディスク読み取り/書き込みトラフィックの要約
このセクションでは、どのプロセスが最も重いディスクの読み取り/書き込みをシステムに実行しているかを特定する方法を説明します。
例4.9 disktop.stp
#!/usr/bin/stap # # Copyright (C) 2007 Oracle Corp. # # Get the status of reading/writing disk every 5 seconds, # output top ten entries # # This is free software,GNU General Public License (GPL); # either version 2, or (at your option) any later version. # # Usage: # ./disktop.stp # global io_stat,device global read_bytes,write_bytes probe vfs.read.return { if ($return>0) { if (devname!="N/A") {/*skip read from cache*/ io_stat[pid(),execname(),uid(),ppid(),"R"] += $return device[pid(),execname(),uid(),ppid(),"R"] = devname read_bytes += $return } } } probe vfs.write.return { if ($return>0) { if (devname!="N/A") { /*skip update cache*/ io_stat[pid(),execname(),uid(),ppid(),"W"] += $return device[pid(),execname(),uid(),ppid(),"W"] = devname write_bytes += $return } } } probe timer.ms(5000) { /* skip non-read/write disk */ if (read_bytes+write_bytes) { printf("\n%-25s, %-8s%4dKb/sec, %-7s%6dKb, %-7s%6dKb\n\n", ctime(gettimeofday_s()), "Average:", ((read_bytes+write_bytes)/1024)/5, "Read:",read_bytes/1024, "Write:",write_bytes/1024) /* print header */ printf("%8s %8s %8s %25s %8s %4s %12s\n", "UID","PID","PPID","CMD","DEVICE","T","BYTES") } /* print top ten I/O */ foreach ([process,cmd,userid,parent,action] in io_stat- limit 10) printf("%8d %8d %8d %25s %8s %4s %12d\n", userid,process,parent,cmd, device[process,cmd,userid,parent,action], action,io_stat[process,cmd,userid,parent,action]) /* clear data */ delete io_stat delete device read_bytes = 0 write_bytes = 0 } probe end{ delete io_stat delete device delete read_bytes delete write_bytes }
例4.9「disktop.stp」 はディスクへの読み取りまたは書き込みが最も多い上位 10 のプロセスを出力します。例4.10「例4.9「disktop.stp」 出力サンプル」 は、このスクリプトの出力サンプルを示しており、リストされたプロセスごとに次のデータが含まれています。
UID
— ユーザー ID。ユーザー ID が0
の場合は、root ユーザーを参照します。PID
— 一覧表示されているプロセスの ID。PPID
— 一覧表示されているプロセスの 親プロセス のプロセス ID。CMD
— 一覧表示されているプロセスの名前。DEVICE
— 一覧表示されているプロセスが、読み取りまたは書き込みを行っているストレージデバイス。T
— プロセスが実行したアクションのタイプ。W
は書き込みを、R
は読み取りを指します。BYTES
— ディスクに対して読み書きされるデータの量。
例4.9「disktop.stp」 の出力の時刻と日付は関数
ctime()
とgettimeofday_s()
によって戻されます。ctime()
は Unix 時間の開始 (1970 年 1 月 1 日) からの経過秒数でカレンダー時間を導出します。gettimeofday_s()
は Unix 時間の開始からの 実際 の秒数をカウントします。これにより、人間が判読できるかなり正確な出力のタイムスタンプが得られます。
このスクリプトでは、
$return
は各プロセスが仮想ファイルシステムから読み書きする実際のバイト数を保存するローカル変数です。$return
は、return プローブ (vfs.read.return
、vfs.read.return
など) でのみ使用できます。
例4.10 例4.9「disktop.stp」 出力サンプル
[...] Mon Sep 29 03:38:28 2008 , Average: 19Kb/sec, Read: 7Kb, Write: 89Kb UID PID PPID CMD DEVICE T BYTES 0 26319 26294 firefox sda5 W 90229 0 2758 2757 pam_timestamp_c sda5 R 8064 0 2885 1 cupsd sda5 W 1678 Mon Sep 29 03:38:38 2008 , Average: 1Kb/sec, Read: 7Kb, Write: 1Kb UID PID PPID CMD DEVICE T BYTES 0 2758 2757 pam_timestamp_c sda5 R 8064 0 2885 1 cupsd sda5 W 1678