028-86922220

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

java中使用JVM命令来实现服务器故障排查的方法

这篇文章给大家分享的是有关java中使用JVM命令来实现服务器故障排查的方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。

创新互联建站坚持“要么做到,要么别承诺”的工作理念,服务领域包括:网站设计、网站建设、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的长春网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

一、top(Linux命令)

执行top命令:    (查看进程15477的详细情况,下文用到)

java中使用JVM命令来实现服务器故障排查的方法

系统信息(前五行):

进程信息:

在top命令中按f按可以查看显示的列信息,按对应字母来开启/关闭列,大写字母表示开启,小写字母表示关闭。带*号的是默认列。

参考  Linux性能分析工具top命令详解

执行top -Hp PID,如 top -Hp 15477

查看某进程中的线程  注:此时PID是线程id

如线程15571有异常需要查看,使用jstack打印堆栈,查看线程15571状态(15571 16进制=3cd3)

java中使用JVM命令来实现服务器故障排查的方法

二、jstack

参考 java命令--jstack 工具

 Java命令学习系列(二)——Jstack

需要到JDK安装目录下使用(可通过ps x查看java进程,得到jdk安装目录)

./jstack PID(进程id)   ./jstack 15477

红框中即为线程15571(16进制=3cd3) 状态

java中使用JVM命令来实现服务器故障排查的方法

分析jstack日志:

java中使用JVM命令来实现服务器故障排查的方法

监视器Monitor:

Monitor是 Java中用以实现线程之间的互斥与协作的主要手段,它可以看成是对象或者 Class的锁。

每一个对象都有,也仅有一个 monitor。

下面这个图,描述了线程和Monitor之间关系,以及线程的状态转换:

java中使用JVM命令来实现服务器故障排查的方法

进入区(Entrt Set):表示线程通过synchronized要求获取对象的锁。如果对象被锁住,则进入拥有者;否则在进入区等待。一旦对象锁被其他线程释放,立即参与竞争。

拥有者(The Owner):表示某一线程成功竞争到对象锁。

等待区(Wait Set):表示线程通过对象的object.wait()方法,释放对象的锁,并在等待区等待被唤醒。

从图中可以看出,一个 Monitor在某个时刻,只能被一个线程拥有,该线程就是 Active Thread,而其它线程都是 Waiting Thread,分别在两个队列 Entry SetWait Set里面等候。

Entry Set中等待的线程动作是 Waiting for monitor entry。

Wait Set中等待的线程动作是 in Object.wait()。当一个线程申请进入临界区时,它就进入了 Entry Set队列。

(我们称被 synchronized保护起来的代码段为临界区。当一个线程申请进入临界区时,它就进入了 “Entry Set ”队列)

线程状态:

NEW:未启动的。不会出现在Dump中。

RUNNABLE:在虚拟机内执行的,运行中状态。The Owner区

BLOCKED:受阻塞并等待监视器锁。在Entry Set区等锁

WATING:无限期等待另一个线程执行特定操作。在Wait Set区等待某个condition或monitor发生,一般停留在wait()等语句里。

TIMED_WATING:有时限的等待另一个线程的特定操作。WaitSet区和WAITING的区别是wait() 等语句加上了时间限制 wait(timeout)。

TERMINATED:已退出的。

调用修饰

表示线程在方法调用时,额外的重要的操作。修饰上方的方法调用。

locked<地址> 目标:使用synchronized申请对象锁成功,监视器的拥有者。The Owner区。

waiting to lock<地址> 目标:使用synchronized申请对象锁未成功,在Entry Set区等锁。线程状态为Blocked

waiting on<地址> 目标:使用synchronized申请对象锁成功后,释放锁,在Wait Set区等锁。线程状态为WAITING或TIMED_WATING

parking to wait for<地址> 目标:调用了park(),在Wait Set区,等待许可。

(park是基本的线程阻塞原语,不通过监视器在对象上阻塞。

park: 进入WAITING状态,对比wait不需要获得锁就可以让线程WAITING,通过unpark唤醒)

线程动作

线程状态产生的原因。

runnable:The Owner区,状态RUNNABLE

in Object.wait():调用wait(),Wait Set区,状态为WAITING或TIMED_WAITING,修饰waiting on

waiting for monitor entry:等锁,Entry Set区,状态BLOCKED,修饰waiting to lock

waiting on condition:因某种条件被park,Wait Set区,状态为parking to wait for

sleeping:休眠的线程,调用了Thread.sleep()

总结

1、查看线程dump,先看线程状态/线程动作(比较直观),可以确定线程目前处于哪个阶段。然后看调用修饰及锁情况,基本就可以确定次线程是否有问题;

2、可以短时间(可能有问题的时间段)内多次打印线程快照,然后查看可能有问题的某一线程在这几次的情况,可以有效查找问题。

三、jps

类似Linux命令ps

参考 Java命令学习系列(一)——Jps

./jps

java中使用JVM命令来实现服务器故障排查的方法

./jps -q

java中使用JVM命令来实现服务器故障排查的方法

./jps -m

java中使用JVM命令来实现服务器故障排查的方法

./jps -l

java中使用JVM命令来实现服务器故障排查的方法

./jps -v

java中使用JVM命令来实现服务器故障排查的方法

四、jmap

参考: Java命令学习系列(三)——Jmap

java命令--jmap命令使用

jmap -heap PID:堆使用情况

jmap -histo PID:对象情况

(jmap -histo:live 这个命令执行,JVM会先触发gc,然后再统计信息

重点看项目上的类:[C是字符串数组,String用;[B是字节数组,网络层用到。这两个比较大一般没关系

 [C is a char[]
  [S is a short[]
  [I is a int[]
  [B is a byte[]
  [[I is a int[][]

感谢各位的阅读!关于java中使用JVM命令来实现服务器故障排查的方法就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!


分享文章:java中使用JVM命令来实现服务器故障排查的方法
URL地址:http://www.tsicrk.com/article/gpheed.html

其他资讯

让你的专属顾问为你服务

2.2333s