java jstack 工具_java命令之jstack工具

1.总述

jstack是jvm虚拟机自带的一种堆栈分析工具,用于打印出给定的java进程或者core file或者远程调试服务的堆栈信息等。主要分为两个功能如下:

a.针对活着的进程做本地的或者远程的线程的dump

b.针对core文件做线程dump

jstack命令可以快捷的定位线程出现长时间停顿的原因,如线程间死锁,死循环,请求外部的资源导致长时间的等待等。

jstack的基本用法

我们在控制台输入 jstack -help,打印如下信息:

[root@izvwwt3webhi84z ~]# jstack -help

Usage:

jstack [-l]

(to connect to running process)

jstack -F [-m] [-l]

(to connect to a hung process)

jstack [-m] [-l]

(to connect to a core file)

jstack [-m] [-l] [server_id@]

(to connect to a remote debug server)

Options:

-F to force a thread dump. Use when jstack does not respond (process is hung)

-m to print both java and native frames (mixed mode)

-l long listing. Prints additional information about locks

-h or -help to print this help message

可以看到有3个参数可供我们的各种需求。

-F 执行线程转储

-m 打印java和本地帧

-l打印列表信息,包括锁相关的信息

线程状态

想要通过jstack查看线程的情况的话,有必要了解线程的几种执行状态,下面这些状态是我们通过jstack查看线程堆栈信息时可能会看到的:

RUNNABLE,在虚拟机内执行的。运行中状态,可能里面还能看到locked字样,表明它获得了某把锁。

BLOCKED,受阻塞并等待监视器锁。被某个锁(synchronizers)給block住了。

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

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

TERMINATED,已退出的

调用修饰

表示线程在调用的时候的额外的重要的操作,线程dump分析的重要信息

locked 使用synchronized申请对象锁成功后,监视器的拥有者

waiting to lock 使用synchronized申请锁对象失败,在进入区等待

waiting on 使用synchronized申请锁对象成功后,在等待区等待

parking to wait for 调用了park方法

线程动作

in object wait() 等待区等待,线程状态可为waiting或者timed_waiting

Reference Handler" #2 daemon prio=10 os_prio=0 tid=0x00007f86a4102000 nid=0xac7 in Object.wait() [0x00007f868edf4000]

java.lang.Thread.State: WAITING (on object monitor)

at java.lang.Object.wait(Native Method)

at java.lang.Object.wait(Object.java:502)

at java.lang.ref.Reference.tryHandlePending(Reference.java:191)

- locked <0x00000000ea2e6d10> (a java.lang.ref.Reference$Lock)

at java.lang.ref.Reference$ReferenceHandler.run(Reference.java:153)

runnable运行状态

waiting on condition 线程状态可为runnable,waiting(parking)或者timed_waiting (sleeping)

logback-1" #10 daemon prio=5 os_prio=0 tid=0x00007f86a42db000 nid=0xacf waiting on condition [0x00007f868c3e1000]

java.lang.Thread.State: WAITING (parking)

at sun.misc.Unsafe.park(Native Method)

- parking to wait for <0x00000000ea203980> (a java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject)

at java.util.concurrent.locks.LockSupport.park(LockSupport.java:175)

at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:2039)

at java.util.concurrent.ScheduledThreadPoolExecutor$DelayedWorkQueue.take(ScheduledThreadPoolExecutor.java:1081)

C1 CompilerThread1 daemon prio=9 os_prio=0 tid=0x00007f86a413e000 nid=0xacb waiting on condition [0x0000000000000000]

java.lang.Thread.State: RUNNABLE

使用实例

jstack查看线程具体在做什么,查看哪些线程在长时间占用cpu,尽快发现问题和解决问题

a.用top命令查看进程消耗cpu的情况,查看消耗高的进程来分析。

top - 23:03:18 up 48 days, 2:07, 2 users, load average: 0.00, 0.01, 0.05

Tasks: 99 total, 1 running, 98 sleeping, 0 stopped, 0 zombie

%Cpu(s): 0.8 us, 0.7 sy, 0.0 ni, 98.5 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st

KiB Mem : 8010460 total, 459580 free, 5867196 used, 1683684 buff/cache

KiB Swap: 0 total, 0 free, 0 used. 1809732 avail Mem

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND

18602 root 20 0 2808772 281956 13840 S 0.7 3.5 6:22.06 java

27484 root 20 0 2947772 417468 14152 S 0.7 5.2 2:52.65 java

32473 root 20 0 2872624 332384 13944 S 0.7 4.1 37:09.33 java

1243 mysql 20 0 1621728 363796 5944 S 0.3 4.5 29:41.37 mysqld

1512 root 20 0 3644460 366936 13808 S 0.3 4.6 21:18.60 java

b.我们可以看到18602的进程消耗cpu比价高,于是可以分析该进程下的线程的使用情况。在控制台输入 top -Hp 18602,如下所示

18603 root 15 0 1807m 630m 9492 S 1.3 4.0 0:05.12 java

20503 root 15 0 1360m 560m 9176 S 0.3 3.6 0:46.72 java

我们来分析18603线程,并且注意18603的线程是属于18602进程的。

输入jstack 18602 | grep -A 10 [线程的16进制]即jstack 18602 | grep -A 10 48ab,得到如下结果

[root@izvwwt3webhi84z ~]# jstack 18602 | grep -A 10 48ab

"DestroyJavaVM" #28 prio=5 os_prio=0 tid=0x00007f119cb24000 nid=0x48ab waiting on condition [0x0000000000000000]

java.lang.Thread.State: RUNNABLE

"New I/O server boss #4" #24 daemon prio=5 os_prio=0 tid=0x00007f119d1c6000 nid=0x48c4 runnable [0x00007f1158912000]

java.lang.Thread.State: RUNNABLE

at sun.nio.ch.EPollArrayWrapper.epollWait(Native Method)

at sun.nio.ch.EPollArrayWrapper.poll(EPollArrayWrapper.java:269)

at sun.nio.ch.EPollSelectorImpl.doSelect(EPollSelectorImpl.java:93)

at sun.nio.ch.SelectorImpl.lockAndDoSelect(SelectorImpl.java:86)

- locked <0x00000000f28b7538> (a sun.nio.ch.Util$3)

- locked <0x00000000f28b7548> (a java.util.Collections$UnmodifiableSet)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/469999.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

最长公共子序列及其引申问题

最长公共子序列是经典的动态规划问题&#xff0c;在很多书籍和文章中都有介绍&#xff0c;这里对这一经典算法进行回顾并对两个follow up questions进行总结和分析。 1. 回顾LCS&#xff08;longest common subsequence&#xff09;解法&#xff0c;求LCS长度 典型的双序列动态…

mysql导入10g数据库_oracle10g数据库导入、导出(exp/imp、expdp/impdp)

1、oracle 10g 数据导入、导出expimpexpdp建目录与赋权&#xff1a;SQL>create directory dump_dir as /u01/dmdir;SQL>grant read&#xff0c;write on directory to test;SQL>select * from dba_directories;——查看目录实例&#xff1a;1、通过DBLINK的方式&#…

JSON.parse和JSON.stringify 参数详解

JSON.parse和JSON.stringify这两个浏览器自带&#xff08;IE6/7除外&#xff09;的方法平常我们经常用到&#xff0c;但是一般都只是用到了他们的第一个参数&#xff0c;比如字符串转对象&#xff1a;JSON.parse({}) 对象转字符串&#xff1a;JSON.stringify({}) 今天特意看了…

怎么用java实现打字功能_怎么用JAVA编写一个打字游戏

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼这个帖子是一年前发的&#xff0c;当时对Java也不是很懂&#xff0c;我看大家都对这个感兴趣&#xff0c;我把代码改了一下&#xff0c;发布出来&#xff0c;其实还有很多的地方还没有完善...&#xff0c;这个只能算一个Demo&#…

从pg_hba.conf文件谈谈postgresql的连接认证

最近一直在弄postgresql的东西&#xff0c;搭建postgresql数据库集群环境什么的。操作数据库少不得要从远程主机访问数据库环境&#xff0c;例如数据库管理员的远程管理数据库&#xff0c;远程的客户存取数据库文件。 而在postgresql中配置文件pg_hba.conf就是用来设置访问认证…

pythonfor循环列表排序_Python Day4950(for循环语句整理)

班长的图Python for循环可以遍历任何序列的项目&#xff0c;如一个列表或者一个字符串。一、Python 循环遍历列表元素1.for i in list():2.for i in enumerate(list):2.for i in range(len(list)):for i in list():for i in enumerate(list):for i in range(len(list)):二、Pyt…

Java异常处理深入理解_关于java异常处理机制的深入理解.doc

关于java异常处理机制的深入理解.doc 关于JAVA异常处理机制的深入理解1引子TRYCATCHFINALLY恐怕是大家再熟悉不过的语句了&#xff0c;而且感觉用起来也是很简单&#xff0c;逻辑上似乎也是很容易理解。不过&#xff0c;我亲自体验的“教训”告诉我&#xff0c;这个东西可不是想…

14款经典的MySQL客户端软件

1. EMS MySQL Manager强大的mysql管理工具&#xff0c;允许用户通过图形界面创建或编辑数据库对象&#xff0c;并提供通过sql语句管理用户和权限&#xff0c;通过图形界面建立sql语句&#xff0c;自动生成html格式的数据库文档&#xff0c;导入/导出数据&#xff0c;查看/编辑b…

java 设计一个动物类_Java课程设计(动物换位)

【实例简介】是一个关于Java课程设计的一个游戏&#xff0c;这是一个动物换位的游戏&#xff0c;是在前人的基础上改进的。不好请见谅&#xff01;【实例截图】【核心代码】112df6fb-1189-4bc0-a501-6dd5839cb8dc└── 【Java课程设计】├── Java课程设计.doc└── 动物换位…

(机器学习/计算机视觉/深度学习)代码

PRML 一书的 matlab implementation&#xff08;官网&#xff1a;http://prml.github.io/&#xff09;一位计算机视觉学术牛人的 Github&#xff08;C code&#xff09;&#xff08;可作为自己的敲门砖&#xff0c;.sln 项目&#xff0c;也即 vs 平台下完成&#xff09;0. 图像…

处理字符集中的算式问题

最近遇到一个编程题.题目是这样的:  接收一个字符型的算式,如"12*34",按顺序,每遇到一个数字,则进行运算至该数字的结果.比如传入的是"12*34",那么结果是1,3,7,11. 有的地方表达可能不一样,我的理解记下来的题目就是这样.回来后写了下,用java语言处理的.…

java 格式化 布尔型_这么久才知道Java中的format很强大!

Java中允许我们对指定的对象进行某种格式化&#xff0c;从而得到我们想要的格式化样式。Format首先介绍java.text包中的FormatForamt是一个抽象基类&#xff0c;其具体子类必须实现format(Object obj, StringBuffer toAppendTo, FieldPosition pos)和parseObject(String source…

【腾讯优测干货分享】从压测工具谈并发、压力、吞吐量

本文来自于腾讯bugly开发者社区&#xff0c;非经作者同意&#xff0c;请勿转载&#xff0c;原文地址&#xff1a;http://dev.qq.com/topic/580d914e07b7fc1c26a0cf7c 前言 随着部门业务的拓展&#xff0c;我们有了很多性能测试的机会&#xff0c;但在实战中&#xff0c;慢慢发现…

java 提高性能的 容器库_容器隔离性带来的问题--容器化Java应用比虚机启动速度慢...

引发的问题同等配置下&#xff0c;虚机中的java 服务的启动速度&#xff0c;要比容器快很多(将近两倍)实测数据在同是1c1g的虚机和容器中&#xff0c;虚机启动时间大概在1min20s&#xff0c;容器启动时间大概在2min40s。排查思路怀疑网络最开始怀疑是网络问题&#xff0c;因为业…

MySQL5.6 PERFORMANCE_SCHEMA 说明

背景&#xff1a; MySQL 5.5开始新增一个数据库&#xff1a;PERFORMANCE_SCHEMA&#xff0c;主要用于收集数据库服务器性能参数。并且库里表的存储引擎均为PERFORMANCE_SCHEMA&#xff0c;而用户是不能创建存储引擎为PERFORMANCE_SCHEMA的表。MySQL5.5默认是关闭的&#xff0c;…

php api查询开发,PHP开发API接口(注册、登录、查询用户信息)的实例代码

本节主要内容&#xff1a;php开发API接口的实现代码一、PHP API接口的服务端部分复制代码 代码示例:/*** PHP开发API接口 服务端* edit: www.jbxue.com*/require conn.php;header(Content-Type:text/html;charsetutf-8);$action $_GET[action];switch ($action) {//注册会员ca…

json字符串与json对象之间的转换

字符串转对象(strJSON代表json字符串) var obj eval(strJSON); &#xff08;运用时候需要除了eval()以外需要json.js包&#xff09; var obj strJSON.parseJSON(); var obj JSON.parse(strJSON)&#xff1b; json对象转字符串(obj代表json对象) var str obj.toJSONS…

ubuntu php 解析,ubuntu运行后台php服务详解

创建一个php服务脚本&#xff0c;该脚本负责抓取mqtt等通信记录&#xff0c;并且保存到数据库。平时&#xff0c;我们只要在服务器端开个终端&#xff0c;就可以运行代码&#xff0c;去抓数据&#xff0c;但是将终端关闭后&#xff0c;就无法抓取数据了。守护进程(daemon)就是一…

04_类与对象_课程动手动脑问题以及课后实验性问题及解答集锦

Answer: 动手动脑&#xff1a; 1——以下代码为何无法通过编译&#xff1f;哪儿出错了&#xff1f; Answer: 因为类Foo的构造函数是有一个参数的&#xff0c;所以我们在new一个Foo类的对象时必须赋予一个符合条件的实参。 2—— 请运行TestStaticInitializeBlock.java示例&…

php如果能编译就完美了,centos7 完美编译PHP7 php-7.2.10.tar.gz

1.下载去官网下载。2、上传并解压tar -zxvf php-7.2.10.tar.gz3、进入文件夹cd php-7.2.104、安装相关依赖包yum install pcre pcre-devel zlib zlib-devel openssl openssl-devel gd gd-devel libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel e2fsprogs e…