JVM 性能调优监控工具
16lz
2021-01-22
声明:本文转自《https://www.cnblogs.com/anxiao/p/6796644.html?utm_source=itdadao&utm_medium=referral》
企业级应用开发中经常会遇到以下问题,可以使用工具对JVM进行监管,以便及时查找问题所在。
1)内存不足OutOfMemory(大对象没有gc等),内存泄露;
2)线程死锁,线程数过多;
3)锁争用(Lock Contention),资源未及时释放(数据库);
4)Java进程CPU消耗过高.
Java安装目录的bin文件加下有一些工具可以用来监控JVM性能,如jconsole、jvisualvm、jmap、jps、jstack、jhat、jstat等。
1. jconsole
jconsole可以监控Java应用程序(如jar应用、tomcat等),但被监视的应用程序必须和jconsole是用同一个用户运行的。jvisualvm的使用和jconsole类似。
- 本地监控: jconsole pid
- 远程监控: jconsole [ hostname:portNum ]
使用远程监控需要配置jmx代理信息,修改Tomcat的bin目录下的catalina.bat。
set JAVA_OPTS= %JAVA_OPTS% -Djava.rmi.server.hostname=HostIP set JAVA_OPTS= %JAVA_OPTS% -Dcom.sun.management.jmxremote.port=8888 set JAVA_OPTS= %JAVA_OPTS% -Dcom.sun.management.jmxremote.ssl=false set JAVA_OPTS= %JAVA_OPTS% -Dcom.sun.management.jmxremote.authenticate=false
更多相关文章
- java线程池深入二
- Java Executor多线程框架
- java线程--volatile实现可见性
- Maven:主线程中的NoClassDefFoundError
- java线程池使用场景和使用方法较详细文摘
- java中多线程安全问题产生&解决方案——同步方法