成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

關(guān)于Java性能監(jiān)控的一些記錄

開發(fā) 后端
本篇所有內(nèi)容都是基于JDK5,如使用JDK6會(huì)有差別。在前些日子,我們做了一些性能監(jiān)控的工作,有一些值得記錄的地方:JDK自身提供了很多工具,基于命令行和GUI的都有,學(xué)會(huì)合理應(yīng)用它們是很有用處的。

本篇所有內(nèi)容都是基于JDK5,如使用JDK6會(huì)有差別。

在前些日子,我們做了一些性能監(jiān)控的工作,有一些值得記錄的地方:

JDK自身提供了很多工具,基于命令行和GUI的都有,學(xué)會(huì)合理應(yīng)用它們是很有用處的。

首先是jmap,這是一個(gè)命令行程序,用來查看JVM中對(duì)象數(shù)量情況,直接輸入jmap會(huì)顯示用法,下面是兩個(gè)常用的功能:

Java代碼

 

 

  1. jmap -histo 'jvmPid' > memory.txt   

 

其中jvmPid為當(dāng)前虛擬機(jī)進(jìn)程的系統(tǒng)ID號(hào),等待過后,memory.txt會(huì)按空間占用由大到小的順序保存當(dāng)前虛擬機(jī)運(yùn)行中存在的對(duì)象類型,我們可以由此看出哪些類型對(duì)象占的空間和生成的數(shù)目較多,尤其是在自定義對(duì)象出現(xiàn)問題導(dǎo)致不能及時(shí)回收,這個(gè)功能是很有用的。

Java代碼

 

 

  1. jmap -heap:format=b 'jvmPid'   

 

和上面的不同,上面是生成一個(gè)文本文件,而這里會(huì)生成一個(gè)二進(jìn)制快照文件,可以用相應(yīng)的分析軟件來打開它來進(jìn)行功能更全面的檢測,如Eclipse Memory Analyzer。

需要注意的是,上面的導(dǎo)出快照命令,在1G左右JVM內(nèi)存的情況下,要大概等待1分鐘左右的時(shí)間,且執(zhí)行時(shí)會(huì)使JVM暫停執(zhí)行,因此不要在正式運(yùn)行系統(tǒng)的高峰期或關(guān)鍵時(shí)刻使用。

接下來是jstat,這也是一個(gè)命令行程序,用來查看JVM的各個(gè)內(nèi)存和GC的使用情況,用法和參數(shù)非常多,有兩個(gè)我們用到的功能:

Java代碼

 

 

  1. jstat -gcutil 'jvmPid'   

 

會(huì)顯示此刻GC的情況,其中YGC和FGC代表小GC和大GC的次數(shù),YGCT和FGCT則代表小GC和大GC運(yùn)行的占用時(shí)間,正常情況下,大GC的次數(shù)應(yīng)遠(yuǎn)遠(yuǎn)小于小GC,例如我當(dāng)前的系統(tǒng)小GC已經(jīng)有10w次,而大GC只有50次,這是程序設(shè)計(jì)運(yùn)行良好的表現(xiàn)。

Java代碼

  1. jstat -gccapacity 'jvmPid'   

會(huì)顯示此刻GC各內(nèi)存池占用量,和上條命令結(jié)果結(jié)構(gòu)類似,同時(shí)也有一個(gè)問題,顯示的數(shù)據(jù)不是很直觀,如果通過GUI觀看就好多了。

JVM自帶了GUI監(jiān)控狀態(tài)的功能,在JDK5中,我們需要做一些配置手動(dòng)開啟它,首先我們要在JVM啟動(dòng)項(xiàng)增加一些屬性,假設(shè)我們的系統(tǒng)是一個(gè)運(yùn)行在tomcat容器下的項(xiàng)目,我們就可以修改JAVA_OPTS變量來開啟監(jiān)控服務(wù)

Java代碼

 

 

  1. JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=12345 -Dcom.sun.management.jmxremote.ssl=false"    

 

這將開啟遠(yuǎn)程基于jmx監(jiān)控的服務(wù)功能,這樣的配置方式,同時(shí)也開啟了默認(rèn)的身份驗(yàn)證機(jī)制,我們還需要在另外的地方設(shè)置權(quán)限,用戶名和密碼才能登錄,我們先把這些服務(wù)端剩下的工作擱置一旁,先說說客戶端的部分。

我們需要GUI客戶端訪問工具來遠(yuǎn)程查看該虛擬機(jī)的信息,JDK5自帶了一個(gè)名為jconsole的客戶端,可以在JDK目錄的bin文件夾下找到它并可以直接雙擊運(yùn)行,點(diǎn)擊“遠(yuǎn)程”標(biāo)簽,之后輸入遠(yuǎn)程IP,端口,用戶名和密碼,如服務(wù)端配置正常,即可成功訪問。

回到服務(wù)端上來,我們還需要配置JVM的遠(yuǎn)程用戶名和密碼,這個(gè)要修改$JAVA_HOME/jre/lib/management/jmxremote.access和jmxremote.password.template文件。

首先直接修改jmxremote.access文件,取消***兩個(gè)用戶名的注釋,改為

Java代碼

 

 

  1. monitorRole   readonly     
  2. controlRole   readwrite \     
  3.               create javax.management.monitor.*,javax.management.timer.* \     
  4.               unregister    

 

這兩個(gè)用戶的區(qū)別顯而易見,你取消一個(gè)當(dāng)然也可以。

然后修改jmxremote.password.template的文件名,將其改成jmxremote.password,之后同樣編輯***兩行用戶,將密碼改成你想要的,很簡單吧。

之后還要做一步,將jmxremote.password文件的權(quán)限改為可讀可寫

Java代碼

 

  1. chmod 600 $JAVA_HOME/jre/lib/management/jmxremote.password   

至此,還有***一點(diǎn)需要注意,要將/etc/hosts文件中127.0.0.1修改成你真正的外網(wǎng)IP,如210.209.83.37,并且運(yùn)行hostname -i命令返回的IP也應(yīng)該是210.209.83.37才可以,每次修改完上述文件,要重新啟動(dòng)JVM,監(jiān)控服務(wù)才會(huì)生效。

大功告成,開啟JVM以后,我們可以運(yùn)行jconsole客戶端,輸入IP端口,用戶名和密碼,用戶名為monitorRole或controlRole或你自定義的(權(quán)限不同)。

也可以免去用戶驗(yàn)證部分,只需要再加入-Dcom.sun.management.jmxremote.authenticate=false即可,也可以通過修改com.sun.management.jmxremote.password.file和com.sun.management.jmxremote.access.file自定義權(quán)限文件和密碼文件的位置,不過這也沒有什么太大必要。

成功登錄后,因?yàn)槭荊UI界面,所有信息可以很直觀的被我們所學(xué)習(xí)和接受,但還需要我們具備一些JVM的知識(shí),尤其是GC方面,有機(jī)會(huì)的話,會(huì)在以后的文檔中繼續(xù)說明。

【編輯推薦】

  1. 巧解IBM JVM for Linux onPOWER性能調(diào)優(yōu)
  2. 海量數(shù)據(jù)存儲(chǔ)之新存儲(chǔ)設(shè)備性能優(yōu)化
  3. 探究JVM1.6與JVM1.5性能差距
  4. 數(shù)據(jù)庫中海量文件的批量轉(zhuǎn)移方法
  5. 海量監(jiān)控的現(xiàn)狀及發(fā)展趨勢研究
責(zé)任編輯:金賀 來源: JavaEye博客
相關(guān)推薦

2021-06-10 10:02:19

優(yōu)化緩存性能

2009-06-18 09:51:25

Java繼承

2012-09-25 10:03:56

JavaJava封面Java開發(fā)

2011-07-13 09:13:56

Android設(shè)計(jì)

2021-02-06 14:25:29

Java延遲加載代碼

2013-04-07 10:40:55

前端框架前端

2011-08-31 10:54:25

Java性能

2017-04-08 17:12:36

設(shè)計(jì)模式抽象策略模式

2012-04-19 10:06:55

微軟Windows 8 E

2020-09-28 06:45:42

故障復(fù)盤修復(fù)

2009-06-04 16:28:43

EJB常見問題

2017-12-21 07:54:07

2022-04-14 10:22:44

故事卡業(yè)務(wù)

2015-12-04 10:04:53

2017-09-05 09:17:47

Java編程用法總結(jié)

2018-07-30 08:41:48

VueReact區(qū)別

2020-04-10 08:50:37

Shell腳本循環(huán)

2020-05-19 14:35:42

Shell腳本循環(huán)

2016-10-18 22:10:02

HTTP推送HTML

2009-08-13 16:41:12

C#結(jié)構(gòu)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 国产丝袜一区二区三区免费视频 | 激情五月婷婷综合 | 国产一级淫片免费视频 | 在线观看国产h | 99久久免费精品国产男女高不卡 | 欧美激情综合五月色丁香小说 | 欧美.com | 91精品国产一区二区在线观看 | 91资源在线 | 日韩精品在线一区 | 欧美极品视频在线观看 | 在线欧美a| 亚洲一区二区在线播放 | 日本免费在线 | 国产精品福利视频 | 国产午夜三级一区二区三 | 高清国产一区二区 | 99精品国产一区二区三区 | 亚洲欧美一区二区三区在线 | 伊人精品在线视频 | 久久国产欧美日韩精品 | 第四色播日韩第一页 | www.一区二区三区.com | 日韩国产中文字幕 | 国产性生活一级片 | 玖玖在线免费视频 | 国产一区免费 | 色资源av| 色综合一区二区 | 请别相信他免费喜剧电影在线观看 | 国产在线高清 | caoporn视频在线 | 成人免费精品视频 | 少妇一级淫片aaaaaaaaa | 亚洲人精品午夜 | 久久激情五月丁香伊人 | 97avcc | 亚洲一区二区三区免费视频 | 日韩欧美在线观看 | 国产精品免费看 | 久久久精品网站 |