Java远程性能分析
2018-12-28 本文已影响25人
阿呆少爷
JMX
启动命令如下。
java -Dcom.sun.management.jmxremote \
-Dcom.sun.management.jmxremote.rmi.port=9091 \
-Dcom.sun.management.jmxremote=true \
-Dcom.sun.management.jmxremote.port=9091 \
-Dcom.sun.management.jmxremote.ssl=false \
-Dcom.sun.management.jmxremote.authenticate=false \
-Dcom.sun.management.jmxremote.local.only=false \
-Djava.rmi.server.hostname=10.10.10.10 \
-jar xxx.jar
data:image/s3,"s3://crabby-images/44516/4451681a238d756243f60e1c67df5540d5d332f6" alt=""
JMX没法使用VisualGC。
data:image/s3,"s3://crabby-images/ddfab/ddfabaf82f64bd70722b84f6f1fa812395654230" alt=""
jstatd
首先配置好policy。
$ cat jstatd.all.policy
grant codebase "file:${java.home}/../lib/tools.jar"
{ permission java.security.AllPermission; };
接着在服务器端先启动jstatd。
jstatd -J-Djava.security.policy=jstatd.all.policy \
-J-Djava.rmi.server.hostname=10.10.10.10 \
-J-Djava.rmi.server.logCalls=true
在jvisualvm里面添加好远程主机,就能看到主机上所有的Java进程。
data:image/s3,"s3://crabby-images/284eb/284eb621146cef260214f518732e3d3ae8934596" alt=""
jstatd看不到CPU的使用情况。
data:image/s3,"s3://crabby-images/318e9/318e93be376f09fae24a3d70efee4d8b2eb4ed78" alt=""
jprofiler
在远程主机下载好 jprofiler,解压开。启动进程的时候,需要指定libjprofilerti.so的路径。
java -agentpath:./jprofiler10.1.4/bin/linux-x64/libjprofilerti.so=port=8849 \
-jar xxx.jar
jprofiler最强大,什么都能看到。
data:image/s3,"s3://crabby-images/7baaa/7baaafe3fc854c09de0192c7d44030e17c5dcc51" alt=""
data:image/s3,"s3://crabby-images/8f259/8f25912553a82ef6109f8e167874b72823ca0274" alt=""