JDK内置工具命令
javap
Java反编译工具,主要用于根据Java字节码文件反汇编为Java源代码文件
用法:javap
用法 | 描述 |
---|---|
javap -help —help -? | 输出此用法消息 |
javap -version | 版本消息 |
javap -v -verbose | 输出附加信息 |
javap -l | 输出行号和本地变量表 |
javap -public | 仅显示公共类和成员 |
javap -protected | 显示受保护的/公共类和成员 |
javap -package | 显示程序包/受保护的/公共类和成员 (默认) |
javap -p -private | 显示所有类和成员 |
javap -c | 对代码进行反汇编 |
javap -s | 输出内部类型签名 |
javap -sysinfo | 显示正在处理的类的系统信息 (路径, 大小, 日期, MD5 散列) |
javap -constants | 显示最终常量 |
javap -classpath | 指定查找用户类文件的位置 |
javap -cp | 指定查找用户类文件的位置 |
javap -bootclasspath | 覆盖引导类文件的位置 |
jps
jps(Java Virtual Machine Process Status Tool)显示当前所有Java进程pid的命令
用法:jps [options] [hostid]
用法 | 描述 |
---|---|
jps -q | 仅输出VM标识符 |
jps -m | 输出main method参数 |
jps -l | 输出完全的包名,应用主类名,jar完全路径名 |
jps -v | 输出JVM参数 |
jps -V | 输出通过flag文件传递到JVM的参数 |
jps -Joption | 传递参数到JVM,如:-J-Xms512m |
jstat
jstat监视Java虚拟机统计信息
用法:jstat - [-t] [-h] [ []]
用法 | 描述 |
---|---|
jstat -gc pid | 显示gc的信息,查看gc的次数及时间 |
jstat -gccapacity pid | 内存GC分区中各对象的使用和占用大小 |
jstat -gcutil pid | 统计gc信息汇总 |
jstat -gcnew pid | 年轻代对象的信息 |
jstat -gcnewcapacity pid | 年轻代对象的信息及其占用量 |
jstat -gcold pid | 老年代对象的信息 |
jstat -gcoldcapacity pid | 老年代对象的信息及其占用量 |
jstat -gcpermcapacity pid | perm对象的信息及其占用量 |
jstat -class pid | 显示加载class数量,及其所占空间 |
jstat -compiler pid | 显示JVM实时编译的数量等信息 |
jstat -printcompilation pid | 打印当前JVM执行的信息 |
关于命令中表头等信息的详细解释可以参考 jstat命令手册
jcmd
jcmd工具可以替代jps工具查看本地的JVM信息
用法: jcmd [pid | main-class] command…|PerfCounter.print|
用法 | 描述 |
---|---|
jcmd | 查看本地的Java进程列表,获取其pid |
jcmd pid help | 查看其支持的命令列表 |
jcmd pid Thread.print -l | 打印线程栈 |
jcmd pid VM.command_line | 打印启动命令及参数 |
jcmd pid VM.system_properties | 查看系统属性内容 |
jcmd pid VM.uptime | 查看虚拟机启动时间 |
jcmd pid GC.heap_dump data/filename.dump | 查看JVM的Heap Dump |
jcmd pid GC.class_histogram | 查看类的统计信息 |
jcmd pid PerfCounter.print | 查看性能统计 |
jinfo
jinfo可以查看运行中JVM的全部参数,还可以设置部分参数
用法:
- jinfo [option] pid
- jinfo [option] executable core
- jinfo [option] [server-id@]remote-hostname-or-ip
参数/option | 描述说明 |
---|---|
pid | 对应JVM的进程id |
excutable core | 产生core dump文件 |
[server-id@]remote-hostname-or-ip | 远程的ip或hostname,server-id标记服务的唯一性id |
no option | 输出全部的参数和系统属性 |
-flag name | 输出对应名称的参数 |
-flag [+/-]name | 开启/关闭对应名称的参数 |
-flag name=value | 设定对应名称的参数 |
-flags | 输出全部的参数 |
-sysprops | 输出系统属性 |
jhat
jhat即Java Heap Analyse Tool,是分析Java堆的命令,可以将堆中的对象以html的形式显示出来,支持对象查询语言OQL
用法:jhat [-stack ] [-refs ] [-port ] [-baseline ] [-debug ] [-version] [-h/-help]
用法参数 | 描述说明 |
---|---|
-J | 启动JVM时传入启动参数,如:-J-XMx512m指定运行jhat的JVM使用的最大堆内存为512m |
-stack false/true | 关闭对象分配调用栈跟踪,默认为true |
-refs false/true | 关闭对象引用跟踪,默认为true |
-port port-number | 设定jhat服务的端口号,默认为7000 |
-exclude exclude-file | 指定文件对象查询时需要排除的数据成员列表,如:指定文件列出了java.lang.String.value,那么当从某个特定对象计算可达对象列表时,引用路径涉及java.lang.String.value的都会被排除 |
-baseline file | 指定一个基准堆转储在两个和heap dumps中有相同object id的对象会被标记为不是新的,其他对象被标记为新的,在比较两个不同的堆转储时很有用 |
-debug int | 设置debug级别,0表示不输出调试信息,值越大表示输出的debug信息越详细 |
-version | 启动后只显示版本信息就退出 |
jmap
jmap会打印Java进程内存中object的情况,或者将JVM中的堆以二进制输出成文本
用法:
- jmap [option] pid
- jmap [option] executable core
- jamp [option] [server-id@] remote-hostname-or-ip
用法参数 | 描述说明 |
---|---|
无参,会打印目标JVM加载的每个共享对象的起始地址,映射大小及映射文件的路径 | |
-dump:[live,] format=b, file= | 使用hprof二进制输出heap内容到文件,live代表只输出存活对象 |
-finalizerinfo | 打印正等候回收的对象的信息 |
-heap | 打印heap的概要信息,GC使用的算法,heap的配置及wise heap的使用情况 |
-histo[:live] | 打印每个class的内存信息,JVM的内部类会加上前缀“*”,live代表只输出存活对象 |
-clstats | 打印classloader和JVM heap方法区的信息,每个classloader的名字,活泼性,地址,父classloader和加载的class数量(另外内部String数量和占用内存数量也会打印出来) |
-F | 强迫,在pid没有响应的时候使用-dump或者-histo参数,在这个模式下,live参数无效 |
-h/-help | 打印辅助信息 |
-J | 传递参数给jmap启动的JVM |
jstack
jstack是堆栈跟踪工具,用于打印给定的Java进程id或core file或远程调试服务的Java堆栈信息,如果在64位机器上,需要指定选项“-J-64”
用法:
- jstack [option] pid
- jstack [option] executable core
- jsatck [option] [server-id@] remote-hostname-or-ip
参数/option | 描述说明 |
---|---|
pid | 对应JVM的进程id |
excutable core | 产生core dump文件 |
[server-id@]remote-hostname-or-ip | 远程的ip或hostname,server-id标记服务的唯一性id |
-F | 强制打印栈信息 |
-l | 长列表,打印关于锁的附加信息 |
-m | 打印Java和native c/c++框架的所有栈信息 |
-h/-help | 打印辅助信息 |
jconsole
jconsole是JDK内置的图形化Java性能分析工具,可以在命令行运行。启动可以更具Java进程id查看程序的堆使用,线程情况,类信息等。
jvisualvm
jvisualvm也是一个可以图形化Java性能分析的工具,在JDK6,JDK7,JDK8中存在,JDK9开始就被移除了,当然用户可以通过visualvm的官方网站自己下载。
JDK内置工具命令的更多相关文章
- 线上问题排查(2)——JDK内置工具
https://www.cnblogs.com/keanuyaoo/p/3253663.html 常用命令目录: jps命令(Java Virtual Machine Process Status T ...
- JDK内置工具之一——JMap(java memory map)
1.介绍 打印出某个java进程(使用pid)内存内的,所有‘对象’的情况(如:产生那些对象,及其数量). 可以输出所有内存中对象的工具,甚至可以将VM 中的heap,以二进制输出成文本.使用方法 j ...
- JDK内置工具使用(jps、jstack、jmap、jstat)
一.JPS 1.jps -lvm:用于查看当前机器上已装载的jvm 二.jstackjstack命令主要用来查看Java线程的调用堆栈的,可以用来分析线程问题(如死锁) 1.jstack -l pid ...
- JDK内置工具jstack(Java Stack Trace)(转)
1.介绍 jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息,如果是在64位机器上,需要指定选项"-J-d64",Windows的js ...
- JDK内置工具使用
- JDK内置性能监测工具使用
Java自带的性能监测工具用法简介——jstack.jconsole.jinfo.jmap.jdb.jsta.jvisualvmJDK内置工具使用 一.javah命令(C Header and Stu ...
- JDK内置日志系统
1.Java应用中的日志功能 ================= 一般的Java应用程序中都有记录日志的需求,目前主流的记录日志的方法是在应用程序中引入log4j,用log4j来生成日志.其实,JDK ...
- 利用Windows内置工具winsat测试硬盘速度(SSD&机械盘对比)
利用Windows内置工具winsat测试硬盘速度(SSD&机械盘对比) 以下是红色内容是在命令行运行: C:\Users\Administrator>winsat diskWindow ...
- SuperSocket内置的命令行协议
内置的命令行协议(接受自定义,分隔符为“:”,“,”): 命令行协议定义了每个请求必须以回车换行结尾 "\r\n". 由于 SuperSocket 中内置的命令行协议用空格来分割请 ...
随机推荐
- 一起学SpringMVC之Json
本文主要以一个简单的小例子,简述SpringMVC开发中,Json的相关应用,仅供学习分享使用,如有不足之处,还请指正. 什么是Json ? JSON 指的是 JavaScript 对象表示法(Jav ...
- C#发送邮件(内容中有图片)
用微软的System.Net.Mail发送邮件,有些时候发邮件需要邮件内容中添加图片. 对象解释 SmtpClient类:允许应用程序使用简单邮件传输协议 (SMTP) 发送电子邮件.MailAddr ...
- Python中编写类的各种技巧和方法
简介 有关 Python 内编写类的各种技巧和方法(构建和初始化.重载操作符.类描述.属性访问控制.自定义序列.反射机制.可调用对象.上下文管理.构建描述符对象.Pickling). 你可以把它当作一 ...
- Add a Parametrized Action 添加带参数的按钮
In this lesson, you will learn how to add a Parametrized Action. These types of Actions are slightly ...
- 搜索某个目录下所有jar包中的mapper目录下的xml文件
rm -rf /mapper/* find /data/app/app-*/lib ! -path "*xnpush*" ! -path "*portal*" ...
- 利用Azure虚拟机安装Dynamics 365 Customer Engagement之一:准备工作
我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...
- Android studio将一个项目作为module导入另一个项目
有两个Android项目,一个为pozhudl,一个为app,现在欲将pozhudl项目作为module导入到app中,并调用pozhudl项目中的类 先在pozhudl项目的build.gradle ...
- 27-限制容器的 Block IO
Block IO 是另一种可以限制容器使用的资源.Block IO 指的是磁盘的读写,docker 可通过设置权重.限制 bps 和 iops 的方式控制容器读写磁盘的带宽,下面分别讨论. 注:目前 ...
- Prometheus Grafana快速搭建
Prometheus Prometheus和Grafana组合基本上是监控系统的标配.Prometheus做存储后端,Grafana做分析及可视化界面. 普罗米修斯是开源的系统监控/报警工具库,功能非 ...
- Python对 Excel 的常用操作
几个常用的对象 Workbook:工作簿,一个包含多个Sheet的Excel文件 Worksheet:工作表,一个Workbook有多个Worksheet,如"Sheet1",&q ...