溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何實現JVM內存監控工具用法

發布時間:2021-10-23 16:53:54 來源:億速云 閱讀:229 作者:柒染 欄目:編程語言

本篇文章為大家展示了如何實現JVM內存監控工具用法,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

你對JVM內存監控工具的使用是否熟悉,這里向大家簡單介紹一下,VisualVM囊括的命令行工具包括jps,jstat,jmap,jinfo,jstack,JConsole,這些工具與JDK的標準版本是一致的,它能為您提供強大的分析能力,實現JVM內存監控。

JVM內存監控工具大全

VisualVM是一種集成了多個JDK命令行工具的可視化工具,它能為您提供強大的分析能力。所有這些都是免費的!它囊括的命令行工具包括jps,jstat,jmap,jinfo,jstack,JConsole,這些工具與JDK的標準版本是一致的。

jinfo:可以輸出并修改運行時的java進程的opts。

jps:與unix上的ps類似,用來顯示本地的java進程,可以查看本地運行著幾個java程序,并顯示他們的進程號。

jstat:一個極強的監視VM內存工具??梢杂脕肀O視VM內存內的各種堆和非堆的大小及其內存使用量。

jmap:打印出某個java進程(使用pid)內存內的,所有‘對象’的情況(如:產生那些對象,及其數量)。

jconsole:一個javaGUI監視工具,可以以圖表化的形式顯示各種數據。并可通過遠程連接監視遠程的服務器VM。

接下來是對這些JVM內存監控工具的詳細介紹:

◆從最簡單的jstat工具開始:我想很多人都是用過unix系統里的ps命令,這個命令主要是用來顯示當前系統的進程情況,有哪些進程,及其id。jps也是一樣,它的作用是顯示當前系統的java進程情況,及其id號。我們可以通過它來查看我們到底啟動了幾個java進程(因為每一個java程序都會獨占一個java虛擬機實例),和他們的進程號(為下面幾個程序做準備),并可通過opt來查看這些進程的詳細啟動參數。
使用方法:在當前命令行下打jps(需要JAVA_HOME,沒有的話,到改程序的目錄下打)

接下來是jstat,我之所以這次調優Liferayportal是因為,liferay在默認的情況下,并發用戶一多就會產生permoutofmomery異常。雖然很開就解決了,但發現對VM內存使用量監控的重要性。通過google,很快的發現了jstat這個工具。

jstat工具特別強大,有眾多的可選項,詳細查看堆內各個部分的使用量,以及加載類的數量。使用時,需加上查看進程的進程id,和所選參數。以下詳細介紹各個參數的意義。
jstat-classpid:顯示加載class的數量,及所占空間等信息。
jstat-compilerpid:顯示VM實時編譯的數量等信息。
jstat-gcpid:可以顯示gc的信息,查看gc的次數,及時間。其中***五項,分別是younggc的次數,younggc的時間,fullgc的次數,fullgc的時間,gc的總時間。

◆jstat-gccapacity:可以顯示,VM內存中三代(young,old,perm)對象的使用和占用大小,如:PGCMN顯示的是最小perm的內存使用量,PGCMX顯示的是perm的內存***使用量,PGC是當前新生成的perm內存占用量,PC是但前perm內存占用量。其他的可以根據這個類推,OC是old內純的占用量。

jstat-gcnewpid:new對象的信息。
jstat-gcnewcapacitypid:new對象的信息及其占用量。
jstat-gcoldpid:old對象的信息。
jstat-gcoldcapacitypid:old對象的信息及其占用量。
jstat-gcpermcapacitypid:perm對象的信息及其占用量。
jstat-utilpid:統計gc信息統計。
jstat-printcompilationpid:當前VM執行的信息。

除了以上一個參數外,還可以同時加上兩個數字,如:jstat-printcompilation30242506是每250毫秒打印一次,一共打印6次,還可以加上-h4每三行顯示一下標題。

◆jmap是一個可以輸出所有內存中對象的JVM內存監控工具,甚至可以將VM中的heap,以二進制輸出成文本。使用方法jmap-histopid。如果連用SHELLjmap-histopid>a.log可以將其保存到文本中去,在一段時間后,使用文本對比工具,可以對比出GC回收了哪些對象。jmap-dump:format=b,file=String3024可以將3024進程的內存heap輸出出來到String文件里。

◆jinfo:此JVM內存監控工具的用處比較簡單,就是能輸出并修改運行時的java進程的運行參數。用法是jinfo-optpid如:查看2788的MaxPerm大小可以用jinfo-flagMaxPermSize2788。

◆jconsole是一個用java寫的GUI程序,用來監控VM,并可監控遠程的VM,非常易用,而且功能非常強。由于是GUI程序,這里就不詳細介紹了,不會的地方可以參考SUN的官方文檔。
使用方法:命令行里打jconsole,選則進程就可以了

上述內容就是如何實現JVM內存監控工具用法,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

jvm
AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女