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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

JVM:查看java内存情况命令

發(fā)布時間:2023/12/13 综合教程 28 生活家
生活随笔 收集整理的這篇文章主要介紹了 JVM:查看java内存情况命令 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

  jmap (linux下特有,也是很常用的一個命令)

  觀察運(yùn)行中的jvm物理內(nèi)存的占用情況。

  參數(shù)如下:

  -heap :打印jvm heap的情況

  -histo: 打印jvm heap的直方圖。其輸出信息包括類名,對象數(shù)量,對象占用大小。

  -histo:live : 同上,但是只答應(yīng)存活對象的情況

  -permstat: 打印permanent generation heap情況

  命令使用:

  jmap -heap 3409

  可以觀察到New Generation(Eden Space,F(xiàn)rom Space,To Space),tenured generation,Perm Generation的內(nèi)存使用情況

  輸出內(nèi)容:

  jmap -histo 3409 | jmap -histo:live 3409

  可以觀察heap中所有對象的情況(heap中所有生存的對象的情況)。包括對象數(shù)量和所占空間大小。

  輸出內(nèi)容:

  寫個腳本,可以很快把占用heap最大的對象找出來,對付內(nèi)存泄漏特別有效。

  如果結(jié)果很多,可以用以下命令輸出到文本文件。

  jmap -histo 3409 | jmap -histo:live 3409 > a.txt

  jinfo:可以輸出并修改運(yùn)行時的java 進(jìn)程的opts。

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

  jstat:一個極強(qiáng)的監(jiān)視VM內(nèi)存工具。可以用來監(jiān)視VM內(nèi)存內(nèi)的各種堆和非堆的大小及其內(nèi)存使用量。

  jmap:打印出某個java進(jìn)程(使用pid)內(nèi)存內(nèi)的所有'對象'的情況(如:產(chǎn)生那些對象,及其數(shù)量)。

  jconsole:一個java GUI監(jiān)視工具,可以以圖表化的形式顯示各種數(shù)據(jù)。并可通過遠(yuǎn)程連接監(jiān)視遠(yuǎn)程的服務(wù)器VM。

  詳細(xì):在使用這些工具前,先用JPS命令獲取當(dāng)前的每個JVM進(jìn)程號,然后選擇要查看的JVM。

  jstat工具特別強(qiáng)大,有眾多的可選項,詳細(xì)查看堆內(nèi)各個部分的使用量,以及加載類的數(shù)量。使用時,需加上查看進(jìn)程的進(jìn)程id,和所選參數(shù)。以下詳細(xì)介紹各個參數(shù)的意義。

  jstat -class pid:顯示加載class的數(shù)量,及所占空間等信息。

  jstat -compiler pid:顯示VM實(shí)時編譯的數(shù)量等信息。

  jstat -gc pid:可以顯示gc的信息,查看gc的次數(shù),及時間。其中最后五項,分別是young gc的次數(shù),young gc的時間,full gc的次數(shù),full gc的時間,gc的總時間。

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

  jstat -gcnew pid:new對象的信息。

  jstat -gcnewcapacity pid:new對象的信息及其占用量。

  jstat -gcold pid:old對象的信息。

  jstat -gcoldcapacity pid:old對象的信息及其占用量。

  jstat -gcpermcapacity pid: perm對象的信息及其占用量。

  jstat -util pid:統(tǒng)計gc信息統(tǒng)計。

  jstat -printcompilation pid:當(dāng)前VM執(zhí)行的信息。

  除了以上一個參數(shù)外,還可以同時加上 兩個數(shù)字,如:jstat -printcompilation 3024 250 6是每250毫秒打印一次,一共打印6次,還可以加上-h3每三行顯示一下標(biāo)題。

  jmap是一個可以輸出所有內(nèi)存中對象的工具,甚至可以將VM 中的heap,以二進(jìn)制輸出成文本。

  命令:jmap -dump:format=b,file=heap.bin

  file:保存路徑及文件名

  pid:進(jìn)程編號

  ?jmap -histo:live pid| less :堆中活動的對象以及大小

  ?jmap -heap pid : 查看堆的使用狀況信息

  jinfo:的用處比較簡單,就是能輸出并修改運(yùn)行時的java進(jìn)程的運(yùn)行參數(shù)。用法是jinfo -opt pid 如:查看2788的MaxPerm大小可以用 jinfo -flag MaxPermSize 2788。

  jconsole是一個用java寫的GUI程序,用來監(jiān)控VM,并可監(jiān)控遠(yuǎn)程的VM,非常易用,而且功能非常強(qiáng)。使用方法:命令行里打 jconsole,選則進(jìn)程就可以了。

  JConsole中關(guān)于內(nèi)存分區(qū)的說明。

  Eden Space (heap): 內(nèi)存最初從這個線程池分配給大部分對象。

  Survivor Space (heap):用于保存在eden space內(nèi)存池中經(jīng)過垃圾回收后沒有被回收的對象。

  Tenured Generation (heap):用于保持已經(jīng)在 survivor space內(nèi)存池中存在了一段時間的對象。

  Permanent Generation (non-heap): 保存虛擬機(jī)自己的靜態(tài)(refective)數(shù)據(jù),例如類(class)和方法(method)對象。Java虛擬機(jī)共享這些類數(shù)據(jù)。這個區(qū)域被分割為只讀的和只寫的,

  Code Cache (non-heap):HotSpot Java虛擬機(jī)包括一個用于編譯和保存本地代碼(native code)的內(nèi)存,叫做“代碼緩存區(qū)”(code cache)

  ?jstack ( 查看jvm線程運(yùn)行狀態(tài),是否有死鎖現(xiàn)象等等信息) : jstack pid : thread dump

  ?jstat -gcutil pid 1000 100 : 1000ms統(tǒng)計一次gc情況統(tǒng)計100次;

  另外推薦一款查看jmap dump 的內(nèi)存對象工具 MemoryAnalyzer

總結(jié)

以上是生活随笔為你收集整理的JVM:查看java内存情况命令的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。