VisualVM:通过SSH监视远程JVM(是否为JMX)
1.交流:JStatD與JMX
VisualVM和JVM之間有兩種通信方式:通過Java Management Extensions (JMX)協(xié)議或通過jstatd 。
jstatd
jstatd是與JDK一起分發(fā)的守護(hù)程序。 在目標(biāo)計(jì)算機(jī)上從命令行啟動它(可能需要以運(yùn)行目標(biāo)JVM的用戶身份或以root用戶身份運(yùn)行它),VisualVM將與它聯(lián)系以獲取有關(guān)遠(yuǎn)程JVM的信息。
- 優(yōu)點(diǎn):可以連接到正在運(yùn)行的JVM,無需使用特殊參數(shù)啟動它
- 缺點(diǎn):監(jiān)視功能受到更多限制(例如,沒有CPU使用率監(jiān)視,無法運(yùn)行Sampler和/或進(jìn)行線程轉(zhuǎn)儲)。
例如:
bash> cat jstatd.all.policy grant codebase 'file:${java.home}/../lib/tools.jar' { permission java.security.AllPermission; } bash> sudo /path/to/JDK/bin/jstatd -J-Djava.security.policy=jstatd.all.policy # You can specify port with -p number and get more info with -J-Djava.rmi.server.logCalls=true注意:如果僅復(fù)制但未安裝JDK,則將“ $ {java.home} /../ lib / tools.jar”替換為絕對的“ /path/to/jdk/lib/tools.jar”。
如果失敗了
Could not create remote object access denied (java.util.PropertyPermission java.rmi.server.ignoreSubClasses write) java.security.AccessControlException: access denied (java.util.PropertyPermission java.rmi.server.ignoreSubClasses write) at java.security.AccessControlContext.checkPermission(AccessControlContext.java:374)那么jstatd可能沒有使用正確的java.security.policy文件啟動(嘗試提供其完全限定的路徑)。
有關(guān)來自O(shè)racle的VisualVM和jstatd的更多信息 。
JMX
- 優(yōu)點(diǎn):使用JMX將為您提供VisualVM的全部功能。
- 缺點(diǎn):需要使用某些系統(tǒng)屬性啟動JVM。
啟動目標(biāo)JVM時,通常將需要使用以下屬性(盡管您也可以啟用SSL和/或要求用戶名和密碼):
yourJavaCommand... -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.port=1098 請參閱遠(yuǎn)程JMX連接 。
2.安全性:SSH
通過ssh連接到遠(yuǎn)程JMX或jstatd的最簡單方法是使用SOCKS代理 ,它可以設(shè)置標(biāo)準(zhǔn)ssh客戶端。
2.1使用SOCKS設(shè)置SSH隧道
2.2配置VisualVM以使用代理
工具->選項(xiàng)->網(wǎng)絡(luò)–手動代理設(shè)置–檢查它并在本地主機(jī)和端口9696上配置SOCKS代理
2.3將VisualVM連接到目標(biāo)
文件->添加遠(yuǎn)程主機(jī)…–鍵入遠(yuǎn)程計(jì)算機(jī)的IP或主機(jī)名JStatD連接
您應(yīng)該在ssh窗口中都看到日志(由于其“ -v”, 例如: “ debug1:端口9696的連接轉(zhuǎn)發(fā)到請求的socks端口0。 ”和“ debug1:通道3:free:direct-tcpip:為10.2.47.71端口1099偵聽端口9696,從127.0.0.1端口61262,nchannels 6 “” 連接并在啟動jstatd的控制臺中(很多,例如“ FINER:RMI TCP Connection(23)-10.2.47.71 :… “)
添加遠(yuǎn)程主機(jī)后,請等待幾分鐘,然后您將看到JVM在其中運(yùn)行。
可用狀態(tài):JVM參數(shù),監(jiān)視器:堆,類,線程監(jiān)視(但不包括CPU)。 采樣器和MBean需要JMX。
JMX
右鍵單擊已添加的遠(yuǎn)程主機(jī),然后選擇“添加JMX連接...”,鍵入您選擇的JMX端口。
您應(yīng)該看到與jstatd類似的日志。
可用的統(tǒng)計(jì)信息:CPU使用率,系統(tǒng)屬性,詳細(xì)的線程報(bào)告(可訪問堆棧跟蹤),CPU采樣(不支持內(nèi)存采樣)。
注意:采樣器與分析器
VisualVM的采樣器不包括在Object.wait和Thread.sleep(例如,等待I / O)中花費(fèi)的時間。 如果您希望獲得更多控制權(quán)或希望包括Object.wait和Thread.sleep時間,請使用NetBeans Profiler來對遠(yuǎn)程應(yīng)用程序進(jìn)行概要分析或采樣。 它要求其Remote Pack(Java代理,即JAR文件)位于目標(biāo)JVM中(NetBeans的附加向?qū)Э梢栽诓襟E4(手動集成)中為您生成遠(yuǎn)程包,并向您展示傳遞給目標(biāo)的選項(xiàng)JVM使用它)。
您可以通過以下方式通過SSH運(yùn)行探查器:轉(zhuǎn)發(fā)其默認(rèn)端口 (5140),并將其附加到本地主機(jī)上的轉(zhuǎn)發(fā)端口(NetBeans版本7.1.1)。
別忘了分享!
參考: VisualVM: The Holy Java博客上來自JCG合作伙伴 Jakub Holy的通過SSH監(jiān)視遠(yuǎn)程JVM(無論是否為JMX) 。
翻譯自: https://www.javacodegeeks.com/2012/09/visualvm-monitoring-remote-jvm-over-ssh.html
總結(jié)
以上是生活随笔為你收集整理的VisualVM:通过SSH监视远程JVM(是否为JMX)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 企业外贸进出口权申请备案流程(企业外贸进
- 下一篇: 美图安卓版下载(美图安卓版)