JVM常用命令:
jps
显示当前运行的java进程以及相关参数
jps参数:
jsp -l pid
-q 只显示pid,不显示class名称,jar文件名和传递给main 方法的参数。
-l 输出应用程序main class的完整package名 或者 应用程序的jar文件完整路径名。
-m 输出传递给main方法的参数
-v 输出传递给JVM的参数
备注:也可以使用ps aux | grep 项目名 查看pid
jstack
用于生成java虚拟机当前时刻的线程快照。
分析CPU利用率100%问题
top 查看占CPU最多的进程
top -Hp pid 查询进程下所有线程的运行情况(shift+p 按cpu排序,shift+m 按内存排序)
用printf ‘%x’ pid 转换为16进制(加入查到的是a)
jstact查看线程快照,jstack 30316 | grep -A 20 a
jmap
用于打印指定Java进程(或核心文件、远程调试服务器)的共享对象内存映射或堆内存细节。
堆Dump是反应Java堆使用情况的内存镜像,其中主要包括系统信息、虚拟机属性、完整的线程Dump、所有类和对象的状态等。 一般,在内存不足、GC异常等情况下,我们就会怀疑有内存泄露。这个时候我们就可以制作堆Dump来查看具体情况。分析原因。
查看java堆(heap)使用情况:jmap -heap 31846
查看java堆(heap)中的对象数量及大小:jmap -histo 31846
将内存使用的详细情况输出到文件: jmap -dump:format=b,file=heapDump pid然后使用jhat -port 5000 heapDump在浏览器中访问:http://localhost:5000/查看详细信息
jinfo
jinfo可以输出java进程、core文件或远程debug服务器的配置信息。可以使用jps -v替换
jstat
是用于监控虚拟机各种运行状态信息的命令行工具。他可以显示本地或远程虚拟机进程中的类装载、内存、垃圾收集、JIT编译等运行数据。
jstat - [-t] [-h] [ []]
参数解释:
Option — 选项,我们一般使用 -gcutil 查看gc情况
vmid — VM的进程号,即当前运行的java进程号
interval– 间隔时间,单位为秒或者毫秒
count — 打印次数,如果缺省则打印无数次
例子:jstat -gc 5828 250 5
javap
可以对代码反编译,也可以查看java编译器生成的字节码。