系統性能監測是 Unix 和 Linux 系統管理員一個重要工做。若是服務器系統性能忽然低於平均應有的狀況,問題可能來自在執行的進程、內存的使用率、磁盤的性能、網絡流量和 CPU 的壓力。在 IT 預算有限的今天,理解如何優化系統性能比以往任什麼時候候都重要。一味地硬件投資並非可以讓人們接受的辦法,而且有時候也不必定生效。一般系統管理員使用一些基礎的工具(top、vmstat、mpstat、ps、free)來辨別和處理一些性能問題。ksar 是 sar 的 Java 圖形化版本,能夠把系統信息如:cpu、內存、網絡、I/O 等使用圖形化方式體現。並且支持能夠監控遠程的 Unix 類操做系統(Linux、AIX、Solaris、HPUX)。java
ksar 簡介ios
一般系統管理員使用一組命令完成以下任務:uptime 顯示系統負載狀況,mpstat 顯示 CPU 性能,free 顯示內存使用狀況,vmstat 顯示虛擬內存使用狀況,iostat 顯示系統 I/O 活動,netstat 顯示網絡的活動,df 和 du 顯示磁盤使用狀況。還可使用 sar 工具完成以上任務,sar 是 System Activity Reporter(系統活動狀況報告)的縮寫。這個工具對於能夠收集系統性能數據,好比 CPU 使用率、硬盤和網絡吞吐數據,經過這些數據的收集和分析,系統管理員能夠判斷系統是否正常運行,是提升系統運行效率的得力助手。服務器
安裝配置 ksar網絡
使用 ksar 以前要安裝配置好 sar,這個工具也包含於大部分 Linux 發行版本中,在 Redhat Linux 中是 sysstat 軟件包。另外您還要配置好 Java JDK 。JDK 版本要求不高,版本高於 1.50 便可。配置完成後,能夠運行以下命令檢查版本號:數據結構
#java -version 架構
若是版本號超過 1.50 ,就可使用 ksar ssh
# wget http://jaist.dl.sourceforge.net/project/ksar/ksar/5.0.6/ksar-5.0.6.zip ide
# unzip ksar-5.0.6.zip 工具
# cd ksar-5.0.6/ 性能
# sh run.sh
圖 1. 第一次運行 ksar 要設置一下目標主機
使用 ksar 分析磁盤 I/O
目前計算機總體的處理器速度、內存大小以及 I/O 執行速度在不斷提升,但 I/O 操做的吞吐率和延遲性能仍然要比等價的內存訪問操做低多個數量級。另外因爲許多工做負荷都擁有重要的 I/O 組件,I/O 處理很容易成爲總體吞吐率和應用總體響應時間的重要瓶頸。針對 I/O 操做密集的應用,性能分析人員必須經過工具來獲取關於 I/O 子系統操做的信息。系統管理員若是要了解磁盤 I/O信息,能夠打開 data 菜單的 Run local command 欄目,而後輸入命令:sar -b 3 12,這個命令表示每隔 3 秒報告磁盤使用狀況,總共運行 12 秒結果如圖 2。圖 2 在數據採集結束後給出了統計平均數據。
圖 2. 使用 ksar 分析磁盤 I/O
參數說明:
ksar 命令使用 -n 選項能夠彙報網絡相關信息,可用的參數包括:DEV、EDEV、SOCK 和 FULL。系統管理員若是要了解網絡信息,能夠打開 data 菜單的 Run local command 欄目而後輸入命令:sar -n DEV 1 2 結果如圖 3 。
圖 3. 使用 ksar 分析網絡信息
參數說明:
rxpck/s:每秒鐘接收到的包數目
txpck/s:每秒鐘發送出去的包數目
rxbyt/s:每秒鐘接收到的字節數
txbyt/s:每秒鐘發送出去的字節數
rxcmp/s:每秒鐘接收到的壓縮包數目
txcmp/s:每秒鐘發送出去的壓縮包數目
txmcst/s:每秒鐘接收到的多播包的包數目
系統性能監測對於系統管理員來講,無疑是一個很是重要的工做,一般系統管理員使用一些基礎的工具(top、vmstat、mpstat、ps、free)來辨別和處理一些性能問題,提升系統運行效率。本文介紹的ksar工具能夠收集系統性能數據,幫助系統管理員們更好的解決問題。
AD: 2013雲計算架構師峯會超低價搶票中
使用 ksar 分析 CPU 信息
系統管理員若是要了解中央處理器的工做信息,能夠打開 data 菜單的 Run local command 欄目而後輸入命令:sar -P ALL 結果如圖 4 。
圖 4. 使用 ksar 分析 CPU 信息
參數說明:
工做負荷有可能會耗盡全部可用的內存。所以有必要利用一些工具來監視內存的使用狀況,例如每一個進程或線程的內核內存佔用量,以及內核數據結構的內存使用機制及其數量和大小。與 CPU 利用狀況同樣,理解操做系統和各個進程的行爲對於跟蹤內存短缺所引發的任何性能問題相當重要。系統管理員若是要了解內存信息,能夠打開 data 菜單的 Run local command 欄目而後輸入命令:sar -r 1 結果如圖 5 。
圖 5. 使用 ksar 分析內存信息
參數說明:
使用 ksar 分析 NFS 信息
網絡文件系統 (Network File System,NFS) 能夠將遠程機器的文件系統與本地文件系統融合起來,即 NFS 使用與本地相同的讀寫接口來遠程訪問數據。系統管理員若是要了解 NFS 信息,能夠打開 data 菜單在 Run local command 欄目而後輸入命令 :sar -n NFS 1 結果如圖 6 。
圖 6. 使用 ksar 分析 NFS 信息
參數說明:
call/s: 每秒成功的 RPC 調用都會使 call/s 的值增加,好比對 NFS 的一次讀 / 寫 。
retrans/s: 每秒重傳的 RPC 次數,好比由於服務器的問題,產生 timeout, 這時客戶端須要從新傳輸 。
read/s: 每秒從 NFS 服務端讀取的次數。
write/s: 每秒寫入到 NFS 服務端的次數。
access/s: 每秒訪問 NFS 的次數,好比從 NFS 服務端 COPY 文件。
getatt/s: 每秒獲取 NFS 服務端文件屬性的次數,好比 ls -l /NFSSERVER/, 若是 NFSSERVER 有 300 個文件,將產生 300 次這樣的請求。
用 ksar 瞭解系統中斷
系統管理員若是要了解系統中斷的使用狀況,能夠打開 data 菜單的 Run local command 欄目而後輸入命令 : :sar -I ALL 1 結果如圖 7。
圖 7. 用 ksar 瞭解系統中斷
參數說明:
intr/s 表示每秒的中斷次數。
使用 ksar 瞭解系統內存分頁
分頁是操做系統中的內存管理機制。經過這種方式計算機能夠爲主存存取其餘存儲介質上的數據。系統管理員若是要了解系統內存分頁信息,能夠打開 data 菜單的 Run local command 欄目,而後輸入命令:sar -B 1 結果如圖 8 。
圖 8. 瞭解系統內存分頁狀況
參數說明:
pgpgin/s: 表示每秒從磁盤或 SWAP 置換到內存的字節數 (KB) 。
pgpgout/s: 表示每秒從內存置換到磁盤或 SWAP 的字節數 (KB) 。
fault/s: 每秒鐘系統產生的缺頁數,即主缺頁與次缺頁之和 (major + minor) 。
majflt/s: 每秒鐘產生的主缺頁數。
使用 ksar 瞭解系統總體全部信息
ksar 提供了一個選項,即 -A,它表明 all,並且仍是大寫的,這個 -A 就至關於全部選項了,打開 data 菜單的 Run local command 輸入命令:sar – A 結果如圖 9。
圖 9. 使用 ksar 瞭解系統全部信息
從圖 8 能夠看到系統使用狀況包括:系統進程、上下文、CPU、中斷、I/O 系統、內存使用、鏈接、系統負載、交換分區、NFS 服務器和客戶端性能包括全部重要信息。另外您能夠把 ksar 的結果導出爲一個文件(文件類型包括 pdf、PNG、JPG、TXT、CVS)。也能夠把一個之前獲得的監控的結果導入 ksar 進行圖形化分析。
設置 ksar 的工做時間段
ksar 也能夠查看非實時的數據,它是經過 cron 週期的運行 sysstat 腳本,將數據產生到指定的目錄下,例如咱們能夠經過「Select time range」菜單選擇起始時間段如圖 10。
圖 10. 選擇起始時間段
遠程使用 ksar
ksar 支持 SSH 鏈接,您可使用它遠程監控其餘 Linux 或其餘 Unix 類型的主機。首先要設置本地主機和遠程主機之間能夠經過自動 SSH 自動登陸,而後打開 data 菜單的 Lanuch ssh command 輸入命令 :ssh goodcjh1@192.168.110.1如圖 11 。
圖 11.ksar 支持 SSH 鏈接
總結
本文介紹了 ksar 這個工具,它基於 sar 的圖形化工具。它能夠從 10 幾個方面對系統的活動進行報告,包括文件的讀寫狀況、系統調用的使用狀況、串口、CPU 效率、內存使用情況、進程活動及 IPC 有關的活動等。這個命令很是複雜,只有經過熟練使用才能掌握。
本文出自:http://os.51cto.com/art/201303/383262_6.htm