1. 程式人生 > >常用的linux系統監控命令

常用的linux系統監控命令

記錄一下自己常用的linux系統命令,方便以後查閱,發覺記憶越來越不行了

找到最耗CPU的java執行緒

ps命令

命令:ps -mp pid -o THREAD,tid,time   或者  ps -Lfp pid

結果展示:

這個命令的作用,主要是可以獲取到對應一個程序下的執行緒的一些資訊。 比如你想分析一下一個java程序的一些執行瓶頸點,可以通過該命令找到所有當前Thread的佔用CPU的時間,也就是這裡的最後一列。

比如這裡找到了一個TID : 30834 ,所佔用的TIME時間最高。

通過 printf "%x\n" 30834 首先轉化成16進位制, 繼續通過jstack命令dump出當前的jvm程序的堆疊資訊。 通過Grep命令即可以查到對應16進位制的執行緒id資訊,很快就可以找到對應最耗CPU的程式碼快在哪。

簡單的解釋下,jstack下這一串執行緒資訊內容: 

Java程式碼  收藏程式碼
  1. "DboServiceProcessor-4-thread-295" daemon prio=10 tid=0x00002aab047a9800 nid=0x7d9b waiting on condition [0x0000000046f66000]  

nid : 對應的linux作業系統下的tid,就是前面轉化的16進位制數字

tid: 這個應該是jvm的jmm記憶體規範中的唯一地址定位,如果你詳細分析jvm的一些記憶體資料時用得上,我自己還沒到那種程度,所以先放下

top命令

命令:top -Hp pid 

結果顯示:

和前面的效果一下,你可以實時的跟蹤並獲取指定程序中最耗cpu的執行緒。 再用前面的方法提取到對應的執行緒堆疊資訊。

判斷I/O瓶頸

mpstat命令

命令:mpstat -P ALL 1 1000

結果顯示:

注意一下這裡面的%iowait列,CPU等待I/O操作所花費的時間。這個值持續很高通常可能是I/O瓶頸所導致的。

通過這個引數可以比較直觀的看出當前的I/O操作是否存在瓶頸

iostat命令

命令: iostat -m -x 1 1000


同樣你可以觀察對應的CPU中的%iowait資料,除此之外iostat還提供了一些更詳細的I/O狀態資料,比如比較重要的有: 

avgqu-sz :  The average queue length of the requests that were issued to the device. (磁碟佇列的請求長度,正常的話2,3比較好。可以和cpu的load一樣的理解)

await : The average time (in milliseconds) for I/O requests issued to the device to be served. (代表一個I/O操作從wait到完成的總時間)

svctm和%util都是代表處理該I/O請求花費的時間和CPU的時間比例。 判斷是否瓶頸時,這兩個引數不是主要的

r/s w/s 和 rMB/s  wMB/s 都是代表當前系統處理的I/O的一些狀態,前者是我們常說的tps,後者就是吞吐量。這也是評價一個系統的效能指標

pid命令

命令: pidstat -p pid -u -d -t -w -h 1 1000

結果顯示:

相當實用的一個命令,可以基於當個程序分析對應的效能資料,包括CPU,I/O,IR , CS等,可以方便開發者更加精細化的觀察系統的執行狀態。不過pidstat貌似是在2.6核心的一些較新的版本才有,需要安裝sysstat包。

ubuntu下,可以通過sudo apt-get install sysstat進行安裝。

sar命令

命令:sar -x pid 1 1000


sar也可以指定對應的pid,關注固定的幾個引數,沒有pidstat那麼強大。 看不到對應的I/O, IR等資訊。

sar的功能可以覆蓋mpstat , iostat的相關功能。

dstat命令

命令:dstat -y --tcp 1 1000


通過dstat --tcp可以比較方便的看到當前的tcp的各種狀態,不需要每次netstat -nat去看

其他命令

netstat -natp  :  檢視對應的網路連結,關注下Recv-Q , Send-Q , State。

lsof -p pid :  查詢對應pid的檔案控制代碼

lsof -i : 80  : 查詢對應埠被哪個程序佔用

lsof  /tmp/1.txt :查詢對應檔案被哪個程序佔用

tcpdump / wireshark :抓包分析工具

jstat / jmap / jstack / jps 等一系列的java監控命令

最後

  如果你想做一些效能調優的工作,一定要善於利用一些工具進行關注相應的狀態。通過linux命令你可以比較方便的觀測到CPU , I/O , network等一些比較外圍的狀態, 很多時候就已經可以解決大部分的問題。jvm內部的一些執行狀態監控,得需要藉助一些特有的工具進行細粒度的觀測。 

相關推薦

常用linux系統監控命令

記錄一下自己常用的linux系統命令,方便以後查閱,發覺記憶越來越不行了 找到最耗CPU的java執行緒 ps命令 命令:ps -mp pid -o THREAD,tid,time   或者  ps -Lfp pid 結果展示: 這個命令的作用,主要是可以獲取到對應一個程序下的執行緒的一些資訊。 比如你想

Linux系統監控命令

load 統計信息 ava 系統 use 資源 page 分配內存 內存大小 top load average: 後面分別是1分鐘、5分鐘、15分鐘的系統負載情況。閾值0.7,高於5的時候就表明系統在超負荷運轉 us:應用程序占用CPU時間百分比 sy: 操作系統占用CPU

性能測試三十三:監控Linux系統監控命令大全

毫秒 car fir ges error 狀態 tac 總數 x86_64 1.top命令top命令是Linux下常用的性能分析工具,能夠實時顯示系統中各個進程的資源占用狀況,類似於Windows的任務管理器。下面詳細介紹它的使用方法。top - 01:06:48 up 1

Linux 系統監控常用命令

索引 zest rec inter 常用命令 節點 bash intern 虛擬 簡介 列舉操作系統級監控常用的幾個方法,建議收藏使用 CPU top 命令可用於監控系統整體負載,包括cpu、內存使用等,能夠實時顯示系統中各個進程的資源占用狀況 輸出樣例 top - 19:

Linux 常用系統工作命令

move roo 怎麽 個數 變量 padding rss comm 釋放 1、echo 命令 echo命令用於在終端輸出字符串或變量提取後的值,格式為“echo [字符串 | $變量]”。 例如,把指定字符串“Linuxprobe.com”輸出到終端屏幕的命令為: [

常用系統監控命令

常用組合方式 vmstat、sar、iostat檢測是否是CPU瓶頸 free、vmstat檢測是否是記憶體瓶頸 iostat檢測是否是磁碟I/O瓶頸 netstat檢測是否是網路頻寬瓶頸 # 用於檢測cpu效能 vmstat 2 3 #每2秒更新資訊,統計3次 procs ---------

常用Linux系統監控工具

1、常用命令  -e 顯示所有 -f 全格式。 -h 不顯示標題。 -l 長格式。 -w 寬輸出。 a 顯示終端上的所有程序,包括其他使用者的 r 只顯示正在執行的程序。 x 顯示沒有控制終端的程序。 Linux系統監控工具 1、mpstat - 多處理器

Linux-常用檢視系統資源命令小結

mpstat:顯示各個可用CPU的狀態 使用:-P 對應cpu編號 例: suhw@ubuntu:~$ mpstat -P ALL Linux 4.13.0-37-generic (ubuntu) 2018年03月26日

常用檢視Linux系統資訊命令總結

系統 # uname -a # 檢視核心/作業系統/CPU資訊 # head -n 1 /etc/issue # 檢視作業系統版本 # cat /proc/cpuinfo # 檢視CPU資訊 # hostname # 檢視計算機名 # l

Linux 系統監控 硬盤分區及格式化

所在 占用 disk str 性能 多個進程 buffer 使用情況 alt top linux系統中性能分析工具,實時顯示系統中各個進程的資源占用情況,類似windows中的資源管理器。 free命令 顯示內存的使用情況,total,used,free,b

linux系統監控與硬盤分區/格式化/文件系統管理

時間 運行 輸入 -c 進程pid 死循環 running ddl 變慢 1.系統監控 1) 系統監視和進程控制的工具----> Top 與 free 類似於windows的資源管理器。 進程運行的三種狀態: tips: 進程(Proce

Linux系統監控工具

linux系統監控工具需要監視Linux服務器的性能?試試這些內置的命令和一些附加的工具吧。大多數Linux發行版都集成了一些監視工具。這些工具可以獲取有關系統活動的信息的詳細指標。通過這些工具,你可以發現產生系統性能問題可能存在原因。下面討論的是一些最基本的命令,它涉及到系統分析和調試服務器等一些問題,如:

系統監控命令---top》

top 監控 如上圖所示,top 模式從上而下分為 3 部分:系統信息區、命令輸入區、進程列表區第一部分 系統信息區 :第一行(top):“00:05:31”為系統當前時刻.“1:05”為系統啟動後到現在的運作時間.“3 users”為當前登錄到系統的用戶,更確切的說是登錄到用戶的終端數 -- 同一

Linux系統基本命令使用

切換 ssh 引號 隱藏 inux start 強制 目錄 use ssh 用戶名@ip地址  Xshell登陸 useradd 用戶名  添加用戶 su - 用戶名  跳轉到用戶名目錄下 [[email protected] ~]# 當前登錄用戶@主機名

Linux系統管理員命令:sudo

可能 優秀 外殼 aca blank su- 錯誤 方式 參數 sudo是個統管一切的命令。它的字面意思是代表“超級用戶才能做!”(super user do!)對Linux系統管理員或高級用戶而言,它是必不可少的最重要的命令之一。你可曾有過這樣的經歷:在終端中試著運行某個

linux系統監控:記錄用戶操作軌跡,誰動過服務器

linux linux script linux安全 linux系統監控 甘兵 1、前言 我們在實際工作當中,都碰到過誤操作、誤刪除、誤修改過配置文件等等事件。對於沒有堡壘機的公司來說,要在linux系統上深究到底誰做過配置文件的修改、做過誤刪除是很頭疼的事情,特別是遇到刪庫跑路

Linux系統壓縮命令匯總

name lena bz2 bzip zip2 com pre 解壓 kernel 01-.tar格式解包:[*******]$ tar xvf FileName.tar打包:[*******]$ tar cvf FileName.tar DirName(註:tar是打包,

centos7常用性能監控命令

centos7常用性能監控命令查看CPU利用率: top 查看CPU信息: lscpu 查看內存信息: free -m 查看磁盤信息: df -h 查看進程信息: ps -aux 查看端口信息: netstat -nutlp centos7常用性能監控命令

Linux系統獲取命令幫助方法及簡單命令介紹

系統 運維 Linux系統中的命令一般分兩種:內部命令和外部命令 1.內部命令:內部命令又稱為內置命令,在系統啟動時就調入內存,是常駐內存的,所以執行效率較高。 2.外部命令:外部命令是系統的軟件功能,用戶需要時才從硬盤中讀入內存。區分內部命令和外部命令的方法:type命令

Linux系統命令別名功能

結果 命令使用 dev gnome 當前 then linux系統 works 可能 在管理和維護Linux系統的過程中,將會使用到大量命令,有一些很長的命令或用法經常被用到,重復而頻繁地輸入某個很長命令或用法是不可取的。這時可以使用命令別名功能將這個過程簡單化。 1.系統