JDK bin指令
jmap:
一、调用命令示例:
jmap -F-dump:format=b,file=rmsheap.bin 6086
就会在当前目录下生成rmsheap.bin的文件,6086是Pid。-F是在某些情况下连不上进程时需要加上。
二、使用:
使用mat进行分析,下载地址:http://www.eclipse.org/mat/downloads.php
可以分析内存泄露,等。还有,能看到当前类的实例个数,以证实是否有些类被占用着没有被回收:
其他的功能待发掘。
jstack:
一、调用命令示例:
jstack -F 3879 >> stack
3879是Pid,-F是连不上进程时使用。导出到stack文件。
二、使用:
Thread31548: (state = BLOCKED)
- Java.lang.Object.wait(long) @bci=0 (Interpretedframe)
- java.lang.Object.wait() @bci=2, line=485(Interpreted frame)
-org.apache.commons.pool.impl.GenericObjectPool.borrowObject() @bci=108,line=811 (Interpreted frame)
-org.apache.commons.dbcp.PoolingDataSource.getConnection() @bci=4, line=96(Interpreted frame)
-org.apache.commons.dbcp.BasicDataSource.getConnection() @bci=4, line=880(Interpreted frame)
看见这些大量阻塞状态的线程,就可以大概猜出来是哪个部件出了问题。然后,可以去google上找找,找不到就看源代码分析了。再结合其他的分析。比如说这个,猜想是取不出线程对象来了,一直在等,分析下代码,看看哪些类有在用,比如看到下面这个:
Connection conn =(Connection)_pool.borrowObject();
if(conn !=null)
conn = new PoolGuardConnectionWrapper(conn);
那么猜想如果借出去了没有换的话,是否PoolGuardConnectionWrapper这个类型的实例应该不少。那就可以从mat里面去看了。再结合数据库池观察软件进行分析。
其他的分析案例可google之。
jstat –gcutil
一、调用命令示例:
jstat-gcutil 21891 250 7
21891 进程号; 250ms 采样interval; 7 count
结果信息:
S0 — Heap上的 Survivor space 0 区已使用空间的百分比
S1 — Heap上的 Survivorspace 1 区已使用空间的百分比
E — Heap上的 Edenspace 区已使用空间的百分比
O — Heap上的 Oldspace 区已使用空间的百分比
P — Perm space 区已使用空间的百分比
YGC — 从应用程序启动到采样时发生 Young GC 的次数
YGCT– 从应用程序启动到采样时 Young GC 所用的时间(单位秒)
FGC — 从应用程序启动到采样时发生 Full GC 的次数
FGCT– 从应用程序启动到采样时 Full GC 所用的时间(单位秒)
GCT — 从应用程序启动到采样时用于垃圾回收的总时间(单位秒)
二、使用:
FGC的次数太频繁,一定要调整,尽量调低这个的次数,耗时耗性能。一般是增加此区的内存。
YGC能少就少。
其他的看比率吧?
JVisualVM:
一、调用命令示例:
直接运行-》jvisualvm
二、使用:
本地的可直接使用,如果要连远程的,需要配置JMX。
在JAVA_OPTS=里增加如下配置
-Dcom.sun.management.jmxremote.port=7028-Dcom.sun.management.jmxremote.ssl=false-Dcom.sun.management.jmxremote.authenticate=false
在运行了jvisualvm的机器上设置:
即可在本地进行分析了。可以看线程、dump线程快照等,可以安装额外的插件进行分析。还可以强制执行GC。
Jconsole
一、调用命令实例:
直接运行-》jvisualvm
Linux下会提示需要图形界面(如果没有的话)
二、使用:
配置JMX与jvisualvm一致。通过下面这种格式的链接进行连接:
service:jmx:rmi:///jndi/rmi://10.211.1.100:7028/jmxrmi
与jvisualvm不同的是mbean,是很多用java类的形式展示的jvm的信息。那应该编程时也可以获取得到。
Jinfo:
一、调用命令实例:
jinfo 8155
二、使用:
输入很多信息,最下面的设置参数信息-opts:,VM Flags:。
Jps:
输出java的进程用。
JDK bin指令的更多相关文章
- Process 'command 'D:\jdk8\jdk\bin\java.exe'' finished with non-zero exit value 2
转载请标明出处,维权必究:https://www.cnblogs.com/tangZH/p/10539006.html 捣鼓了好久,现在已经不想说话,为何会出现这个问题,Process 'comman ...
- JDK/bin下工具列表说明
JDK/bin下工具列表说明 appletviewer.exe:一种执行HTML文件上的Java小程序类的Java浏览器 apt.exe:注解处理工具(Annotation Processing To ...
- 往jdk/bin目录中增加tcnative-1.dll文件以后报错 Can't load AMD 64-bit .dll on a IA 32-bit platform
开始时,运行Tomcat控制台报错: The APR based Apache Tomcat Native library which allows optimal performance in pr ...
- -bash: /root/java/jdk/bin/java: cannot execute binary file
错误 -bash: /root/java/jdk/bin/java: cannot execute binary file 错误原因 安装的Linux的版本是32位的,下载的软件是64位,版本不兼容, ...
- java中jre\bin目录和jdk\bin目录下的工具功能介绍
转自:https://blog.csdn.net/eclipse_yin/article/details/51051096 jre/bin目录下面工具说明 javac:Java编译器,将Java源代码 ...
- linux jdk bin安装
1.jdk-1_5_0_06-linux-i586.bin下载到/usr/soft,赋予可执行权限:chmod 755jdk-1_5_0_06-linux-i586.bin 2.执行:./jdk-1_ ...
- JDK/bin目录下的不同exe文件的用途(转)
新安装完JDk 大家是否发现安装目录的bin文件夹有很多exe文件 下面就为大家讲解不同exe文件的用途 javac:Java编译器,将Java源代码换成字节代 java:Java解释器,直接从类文件 ...
- LR使用Java User协议环境报错Please add the <JDK>\bin to the path and try again
看标题报错信息就知道,这是java编译及运行环境配置问题,运行LR脚本时,LR代理找不到java的JDK环境,当然,可能有人会遇到说,我在cmd窗口javac 环境是没问题的呀,是的,这就要看你的jd ...
- JDK/bin目录下的不同exe文件的用途
新安装完JDk 大家是否发现安装目录的bin文件夹有很多exe文件 下面就为大家讲解不同exe文件的用途 javac:Java编译器,将Java源代码换成字节代 java:Java解释器,直接从类文件 ...
随机推荐
- C++设计模式之-外观模式
意图: 为子系统中的一组接口提供一个一致的界面,此模式定义了一个高层接口,这个接口使得这一系统更加容易使用. 适用性: 1.在设计初期阶段,应该要有意识的将不同的两个层分离,比如经典的三层架构,就需要 ...
- 备注下Windows可能会用到的运行命令
因为有几个命令不常用忘记了,所以备注下Windows可能会用到的运行命令: 1.cleanmgr:打开磁盘清理工具2.compmgmt.msc:计算机管理3.charmap:启动字符映射表4.calc ...
- IGMP 因特网组管理协议
IGMP(Internet Group Management Protocol)作为因特网组管理协议,用于多播. 与ICMP一样, IGMP也被当作 IP 层的一部分,IGMP报文也通过IP数 ...
- Azure 软件架构选择
1. 传统的分层结构+message broker + worker传统的层结构老生常谈了: UI 层,service,业务逻辑,数据层.就不赘述了与worker形成producer-consumer ...
- tomcat的localhost-config is missing 错误的解决方法
运行项目时报错,错误信息为: The tomcat server configuration at /sever/tomcat v7.0 localhost-config is missing 解决方 ...
- TCP/IP 必知必会的十个问题
本文整理了一些TCP/IP协议簇中需要必知必会的十大问题,既是面试高频问题,又是程序员必备基础素养. 一.TCP/IP模型 TCP/IP协议模型(Transmission Control Protoc ...
- css---选择器的特殊性
特殊性这点吃了亏,是该梳理一下了~ 先说一下大概的选择器,沾代码 最权威的还是<css权威指南> 我们把特殊性分为4个等级,每个等级代表一类选择器,每个等级的值为其所代表的选择器的个数乘以 ...
- Linux 用C语言实现简单的shell(2)
不知不觉两周没有发文了,因为“一万美金的福特奖学金答辩”,ACM比赛,网络论文阅读和网络大作业一大堆事把时间冲散了,所以先写一篇博文补上之前一坑. 之前发了一篇关于linux 用C语言实现简单shel ...
- BZOJ5142: [Usaco2017 Dec]Haybale Feast(双指针&set)(可线段树优化)
5142: [Usaco2017 Dec]Haybale Feast Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 182 Solved: 131[ ...
- hive表数据导出到csv乱码原因及解决方案
转载自http://blog.csdn.net/lgdlxc/article/details/42126225 Hive表中的数据使用hive - e"select * from table ...