JVM性能调优监控工具jps、jstack、jstat、jmap、jinfo使用详解

jcmd命令:主要提供JVM的一些基本信息查询(查看进程运行时间、查看虚拟机版本信息、显示调优标志)

jinfo命令:查看进程ID号。查看JVM的配置参数。

jps

查看所有的jvm进程,包括进程ID,进程启动的路径等等。

我自己也用PS,即:ps -ef | grep java

jstack

观察jvm中当前所有线程的运行情况和线程当前状态。

系统崩溃了?如果java程序崩溃生成core文件,jstack工具可以用来获得core文件的java stack和native stack的信息,从而可以轻松地知道java程序是如何崩溃和在程序何处发生问题。

系统hung住了?jstack工具还可以附属到正在运行的java程序中,看到当时运行的java程序的java stack和native stack的信息, 如果现在运行的java程序呈现hung的状态,jstack是非常有用的。

jstat

jstat利用JVM内建的指令对Java应用程序的资源和性能进行实时的命令行的监控,包括了对进程的classloader,compiler,gc情况;

特别的,一个极强的监视内存的工具,可以用来监视VM内存内的各种堆和非堆的大小及其内存使用量,以及加载类的数量。

jmap

监视进程运行中的jvm物理内存的占用情况,该进程内存内,所有对象的情况,例如产生了哪些对象,对象数量;

系统崩溃了?jmap 可以从core文件或进程中获得内存的具体匹配情况,包括Heap size, Perm size等等

jinfo

观察进程运行环境参数,包括Java System属性和JVM命令行参数

系统崩溃了?jinfo可以从core文件里面知道崩溃的Java应用程序的配置信息。


垃圾回收用什么查看(eclipse 加参数、 jstatjmap+MAT

SpringMVC 初始化完成的方法/标志/事件:实现ApplicationListener接口,使用@PostConstruct注解,方法实现InitializingBean或者ServletContextAware



猜你喜欢

转载自blog.csdn.net/qiuchaoxi/article/details/80730617