日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > linux >内容正文

linux

java sar包_linux下查看最占性能的JAVA进程

發布時間:2024/7/5 linux 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java sar包_linux下查看最占性能的JAVA进程 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

記錄一下自己常用的linux系統命令,方便以后查閱,發覺記憶越來越不行了找到最耗CPU的線程

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下這一串線程信息內容:

800 nid=0x7d9b waiting on condition

[0x0000000046f66000]

"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

總結

以上是生活随笔為你收集整理的java sar包_linux下查看最占性能的JAVA进程的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。