dstat
通用的系統資源統計工具
補充說明
dstat命令 是一個用來替換vmstat、iostat、netstat、nfsstat和ifstat這些命令的工具,是一個全能系統信息統計工具。與sysstat相比,dstat擁有一個彩色的界面,在手動觀察性能狀況時,數據比較顯眼容易觀察;而且dstat支持即時刷新,譬如輸入dstat 3
即每三秒收集一次,但最新的數據都會每秒刷新顯示。和sysstat相同的是,dstat也可以收集指定的性能資源,譬如dstat -c
即顯示CPU的使用情況。
下載安裝
方法一
1yum install -y dstat
方法二
官網下載地址:http://dag.wieers.com/rpm/packages/dstat
1wget http://dag.wieers.com/rpm/packages/dstat/dstat-0.6.7-1.rh7.rf.noarch.rpm
2rpm -ivh dstat-0.6.7-1.rh7.rf.noarch.rpm
使用說明
安裝完後就可以使用了,dstat非常強大,可以實時的監控cpu、磁盤、網絡、IO、內存等使用情況。
直接使用dstat,默認使用的是-cdngy
參數,分別顯示cpu、disk、net、page、system信息,默認是1s顯示一條信息。可以在最後指定顯示一條信息的時間間隔,如dstat 5
是沒5s顯示一條,dstat 5 10
表示沒5s顯示一條,一共顯示10條。
1[root@iZ23uulau1tZ ~]# dstat
2----total-cpu-usage---- -dsk/total- -net/total- ---paging-- ---system--
3usr sys idl wai hiq siq| read writ| recv send| in out | int csw
4 0 0 99 0 0 0|7706B 164k| 0 0 | 0 0 | 189 225
5 0 0 100 0 0 0| 0 0 |4436B 826B| 0 0 | 195 248
6 1 0 99 0 0 0| 0 0 |4744B 346B| 0 0 | 203 242
7 0 0 100 0 0 0| 0 0 |5080B 346B| 0 0 | 206 242
8 0 1 99 0 0 0| 0 0 |5458B 444B| 0 0 | 214 244
9 1 0 99 0 0 0| 0 0 |5080B 346B| 0 0 | 208 242
下面對顯示出來的部分信息作一些說明:
- cpu:hiq、siq分別爲硬中斷和軟中斷次數。
- system:int、csw分別爲系統的中斷次數(interrupt)和上下文切換(context switch)。
其他的都很好理解。
語法
1dstat [-afv] [options..] [delay [count]]
常用選項
1-c:顯示CPU系統佔用,用戶佔用,空閒,等待,中斷,軟件中斷等信息。
2-C:當有多個CPU時候,此參數可按需分別顯示cpu狀態,例:-C 0,1 是顯示cpu0和cpu1的信息。
3-d:顯示磁盤讀寫數據大小。
4-D hda,total:include hda and total。
5-n:顯示網絡狀態。
6-N eth1,total:有多塊網卡時,指定要顯示的網卡。
7-l:顯示系統負載情況。
8-m:顯示內存使用情況。
9-g:顯示頁面使用情況。
10-p:顯示進程狀態。
11-s:顯示交換分區使用情況。
12-S:類似D/N。
13-r:I/O請求情況。
14-y:系統狀態。
15--ipc:顯示ipc消息隊列,信號等信息。
16--socket:用來顯示tcp udp端口狀態。
17-a:此爲默認選項,等同於-cdngy。
18-v:等同於 -pmgdsc -D total。
19--output 文件:此選項也比較有用,可以把狀態信息以csv的格式重定向到指定的文件中,以便日後查看。例:dstat --output /root/dstat.csv & 此時讓程序默默的在後臺運行並把結果輸出到/root/dstat.csv文件中。
當然dstat還有很多更高級的用法,常用的基本這些選項,更高級的用法可以結合man文檔。
實例
如想監控swap,process,sockets,filesystem並顯示監控的時間:
1[root@iZ23uulau1tZ ~]# dstat -tsp --socket --fs
2----system---- ----swap--- ---procs--- ------sockets------ --filesystem-
3 date/time | used free|run blk new|tot tcp udp raw frg|files inodes
426-07 09:23:48| 0 0 | 0 0 0.0|104 8 5 0 0| 704 6488
526-07 09:23:49| 0 0 | 0 0 0|104 8 5 0 0| 704 6488
626-07 09:23:50| 0 0 | 0 0 0|104 8 5 0 0| 704 6489
726-07 09:23:51| 0 0 | 0 0 0|104 8 5 0 0| 704 6489
826-07 09:23:52| 0 0 | 0 0 0|104 8 5 0 0| 704 6489
926-07 09:23:53| 0 0 | 0 0 0|104 8 5 0 0| 704 6489
若要將結果輸出到文件可以加--output filename
:
1[root@iZ23uulau1tZ ~]# dstat -tsp --socket --fs --output /tmp/ds.csv
2----system---- ----swap--- ---procs--- ------sockets------ --filesystem-
3 date/time | used free|run blk new|tot tcp udp raw frg|files inodes
426-07 09:25:31| 0 0 | 0 0 0.0|104 8 5 0 0| 736 6493
526-07 09:25:32| 0 0 | 0 0 0|104 8 5 0 0| 736 6493
626-07 09:25:33| 0 0 | 0 0 0|104 8 5 0 0| 736 6493
726-07 09:25:34| 0 0 | 0 0 0|104 8 5 0 0| 736 6493
826-07 09:25:35| 0 0 | 0 0 0|104 8 5 0 0| 736 6494
926-07 09:25:36| 0 0 | 0 0 0|104 8 5 0 0| 736 6494
這樣生成的csv文件可以用excel打開,然後生成圖表。
通過dstat --list
可以查看dstat能使用的所有參數,其中上面internal是dstat本身自帶的一些監控參數,下面/usr/share/dstat
中是dstat的插件,這些插件可以擴展dstat的功能,如可以監控電源(battery)、mysql等。
下面這些插件並不是都可以直接使用的,有的還依賴其他包,如想監控mysql,必須要裝python連接mysql的一些包。
1[root@iZ23uulau1tZ ~]# dstat --list
2internal:
3 aio, cpu, cpu24, disk, disk24, disk24old, epoch, fs, int, int24, io, ipc, load, lock, mem, net, page, page24, proc, raw, socket, swap, swapold, sys, tcp, time, udp, unix, vm
4/usr/share/dstat:
5 battery, battery-remain, cpufreq, dbus, disk-util, fan, freespace, gpfs, gpfs-ops, helloworld, innodb-buffer, innodb-io, innodb-ops, lustre, memcache-hits, mysql-io, mysql-keys, mysql5-cmds, mysql5-conn, mysql5-io, mysql5-keys,
6 net-packets, nfs3, nfs3-ops, nfsd3, nfsd3-ops, ntp, postfix, power, proc-count, rpc, rpcd, sendmail, snooze, thermal, top-bio, top-cpu, top-cputime, top-cputime-avg, top-io, top-latency, top-latency-avg, top-mem, top-oom, utmp,
7 vm-memctl, vmk-hba, vmk-int, vmk-nic, vz-cpu, vz-io, vz-ubc, wifi
dstat命令的基本用法就說到這裏,更多用法有待摸索,如果您需要補充內容請給我們發郵件,謝謝!
來源:https://github.com/jaywcjlove/linux-command
版權申明:
- 未標註來源的內容皆為原創,未經授權請勿轉載(因轉載後排版往往錯亂、內容不可控、無法持續更新等);
- 非營利為目的,演繹本博客任何內容,請以'原文出處'或者'參考鏈接'等方式給出本站相關網頁地址(方便讀者)。