JVM监控工具VisualVM的使用
VisualVM是jvm的可视化监控工具
下载地址:http://visualvm.java.net/download.html
监控本地jvm很简单,这里不详细说了。
监控远程jvm的方法有2种
一、远程服务器启动jstatd守护进程
./jstatd -J-Djava.security.policy=jstatd.all.policy -J-Djava.rmi.server.hostname=192.168.0.50 -J-Djava.rmi.server.logCalls=true -p 1011
1、 在JDK/bin下新建一文本文件, 名称 jstatd.all.policy
内容如下:
grant codebase "file:${java.home}/../lib/tools.jar" {
permission java.security.AllPermission;
};
2、 运行 jstatd -J-Djava.security.policy=jstatd.all.policy
若需要指定端口, 请使用 -p 1011
指定守护进程监听的ip(默认是127.0.0.1),请使用-J-Djava.rmi.server.hostname=192.168.0.50
查看日志,请使用-J-Djava.rmi.server.logCalls=true
另外注意防火墙,需要使用1011之外的其他端口
3、 在终端启动VisualVM.
二、JMX方式
1、JAVA_OPTS="Dcom.sun.management.jmxremote.port=8999 -Dcom.sun.management.jmx
remote.ssl=false -Dcom.sun.management.jmxremote.authenticate=true -Djava.rmi.server.hostname=192.168.0.50"
2、鉴权方法
jdk/jre/lib/management/jmxremote.access 定义了2种权限,读写和只读
monitorRole readonly表示只能监控
controlRole readwrite表示可以修改jmx的各项配置
可以添加任意用户,如:
admin readwrite
jdk/jre/lib/management/jmxremote.password
定义了jmxremote.access中的用户名的密码,如:
admin 111111
三、VisaulVM插件
菜单:工具->插件->可用插件(下载)
现在要下载的插件安装即可。几个有用的插件:
1、Visaul GC,可以参考详细的GC信息和内存使用情况,很详细哦。不过远程访问不支持JMX方式,必须用jstatd方式
2、Visaul MBeans,jmx管理界面,可以管理应用中个所有mbean。如果使用spring,可以通过spring的jmx整合,将bean暴露出来,即可实时的修改各项应用配置。
3、Profile,cpu和内存性能分析,可以按照包名过滤不需要监控的类
3、BTrace,可以在不宕机的情况下调试代码。在visualVM上可以右键选中Trace Applicationg...打开BTrace窗口(只支持本地jvm),下面这个是查看某个方法的执行时间的示例:
/* BTrace Script Template */
import com.sun.btrace.annotations.*;
import static com.sun.btrace.BTraceUtils.*;
@BTrace
public class TracingScript {
@TLS
private static long startTime = 0;
@OnMethod(clazz="com.aspire.pams3.verify.audit.action.audit.AuditAction", method="getAuditContent")
public static void startMethod() {
startTime = timeMillis();
}
@OnMethod(clazz="com.aspire.pams3.verify.audit.action.audit.AuditAction", method="getAuditContent", location=@Location(Kind.RETURN))
public static void endMethod() {
print(strcat(strcat(name(probeClass()), "."), probeMethod()));
print(" [");
print(strcat("Time taken : ", str(timeMillis() - startTime)));
println("]");
}
}
如果需要在远程服务器执行,需要下载http://kenai.com/projects/btrace/downloads/directory/releases
将上面的代码保存为TracingScript.java
执行./btrace <pid> TracingScript.java
4、OQL,对象查询语言
推荐阅读
-
JVM监控工具VisualVM的使用
-
visualvm jmx 监控linux上的tomcat
-
配置visualvm远程监控JVM
-
jvm参数实战:VisualVM工具对Eclipse性能调优
-
python使用Windows的wmic命令监控文件运行状况,如有异常发送邮件报警
-
Android IoT开发实战 | 03 - Android日志工具Log的使用
-
Android Studio 的代码检查功能,使用 Lint 工具优化代码(笔记)
-
python使用pyhook监控键盘并实现切换歌曲的功能
-
AI怎么使用混合工具设计点状文字? AI圆点文字的设计方法
-
zabbix3.0.4监控centos7 根目录使用率的脚本