jps
显示系统内所有的java进程信息 类似linux中的ps命令
选项参数
参数 | 作用 |
---|---|
-m | 输出main函数的参数 |
-l | 输出main的全类名,如果是jar,输出jar的路径 |
-v | 输出进程的jvm参数 |
jstat
收集java进程运行过程中的各种数据 ,主要监控gc数据
命令格式
jstat option vmid interval[s|ms] [count]
例如 jstat -gc 1234 500 10 查看oid为1234 的gc信息 每500ms输出一次 共打印10次
选项参数
jinfo
实时的查看和调整虚拟机的各项参数
命令格式
jinfo [option] pid
例如:
jinfo -flag CMSInitiatingOccupancyFraction 1444 查看虚拟机CMSInitiatingOccupancyFraction 参数的值
jinfo -flag +|- name pid 开启关闭虚拟机阐述
jinfo -flag name=value pid 修改虚拟机参数
jinfo -flags pid 打印虚拟机参数
jinfo -sysprops 打印jvm中 System.getProperties()可以获取到参数
jmap
生成虚拟机的内存快照文件heapdump,还可以查看java堆和元空间的详细信息,如空间使用率、当前使用的哪种收集器等。
命令格式
jmap [option] pid
jmap -dump:format=b,file=eclipse.bin 3500
jmap -heap 3500 显示java堆详细信息
jmap -histo[:live] 3500 显示堆中对象的统计信息,包括类、实例数量、合计容量
选项参数
jstack
显示虚拟机当前时刻的线程快照。线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照可以定位线程长时间停顿的原因,如线程死锁、死循环、请求外部资源时间过长等问题。
命令格式
jstack [option] vmid
选项参数
线程的状态
java中定义了5种线程状态,在任意一个时间点,一个线程只能有且只有其中一种状态,这5中状态分别如下:
- 新建(New):创建后尚未启动的线程处于这种状态
- 运行(Runnable):Runnable包括了操作形同线程状态中的Running和Ready,也就是处于此状态的线程有可能正在执行,也有可能正在等待着CPU为它分配执行时间
- 无限期等待(waiting):处于这种状态的线程不会被分配CPU执行时间,他们要等待被其他线程显示的唤醒。以下方法会让线程陷入无限期的等待状态
- 没有设置Timeout参数的Object.wait方法
- 没有设置Timeout参数的Thread.join()方法
- LockSupport.pack方法
- 限期等待(Timed Waiting):处于这种状态的线程也不会被分配cpu执行时间,不够无需等待被其他线程显示的唤醒,在一定时间之后他们会由系统自动唤醒。以下方法会让线程进入限期等待状态
- Thread.sleep()
- 设置了Timeout参数的Object.wait()方法
- 设置了Timeout参数的Thread.join()方法
- LockSupport.parkNanos方法
- LockSupport.parkUntil方法
- 阻塞(Blocked):线程被阻塞了,阻塞状态与等待状态的区别是:阻塞状态在等待获取一个排它锁,这个事件将在另外一个线程释放这个锁的时候发生:而等待状态则是在等待一段时间,或者唤醒动作的发生。在程序等待进入同步区域的时候,线程将进入这种状态。
- 结束(Terminated):已终止线程的线程状态,线程已经结束执行。
jhat
用于分析heapdump文件,与jmap搭配使用,来分析jmap生成的堆转储快照,jhat内置了一个http服务器,分析jmap结果后,可以在浏览器中查看分析结果。在实际工作中一般不会使用此工具,因为此工具的分析功能相对简陋。
Eclipse Memory Analyzer、IBM HeapAnalyzer、VisualVM功能更加强大,可以替代jhat。