java进程CPU高分析
JVM导致系统CPU高的常见场景:
内存不足,JVM gc频繁,一般会伴随OOM
JVM某个线程死循环或者递归调用
定位和解决
1.内存不足,gc频繁可参考我的这遍文章解决。https://blog.csdn.net/moranzi1/article/details/88670204
2.JVM某个线程死循环或者递归调用。这种情况关键是找到导致CPU高的线程。然后根据具体线程具体分析为什么该线程会导致CPU高。需要线程的步骤如下。
top——命令查看cpu高的进程
[root@iZwz9gs2zseivevv1k5vnkZ syp]# top
top - :: up days, :, users, load average: 4.59, 4.16, 3.26
Tasks: total, running, sleeping, stopped, zombie
%Cpu(s): 84.1 us, 4.5 sy, 0.0 ni, 10.8 id, 0.1 wa, 0.0 hi, 0.6 si, 0.0 st
KiB Mem : total, free, used, buff/cache
KiB Swap: total, free, used. avail Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
root S 293.0 6.0 :23.05 java
root S 15.9 3.2 : java
root S 12.0 5.0 : java
root S 2.3 5.3 :16.27 java
root S 2.0 4.8 :26.20 java
root - S 2.0 0.1 :57.96 AliYunDun
ps aux | grep PID——命令查看具体进程信息
ps -mp pid -o THREAD,tid,time——命令查看进程线程信息,找到导致CPU高的线程TID
[root@iZwz9gs2zseivevv1k5vnkZ syp]# ps -mp -o THREAD,tid,time
USER %CPU PRI SCNT WCHAN USER SYSTEM TID TIME
root 22.7 - - - - - - ::
root 0.0 - futex_ - - ::
root 0.1 - futex_ - - ::
root 4.6 - - - - ::
root 4.6 - - - - ::
root 4.6 - - - - ::
root 4.6 - - - - ::
root 1.2 - futex_ - - ::
printf "%x\n" tid——命令转换线程为16进制格式
[root@iZwz9gs2zseivevv1k5vnkZ syp]# printf “%x\n”
“2f4dn” [root@iZwz9gs2zseivevv1k5vnkZ syp]# printf “%x\n”
“2f4en” [root@iZwz9gs2zseivevv1k5vnkZ syp]# printf “%x\n”
“2f4fn” [root@iZwz9gs2zseivevv1k5vnkZ syp]# printf “%x\n”
“2f50n”
jstack pid |grep tid -A 30——命令查看线程信息,定位到具体线程
[root@iZwz9gs2zseivevv1k5vnkZ syp]# jstack | grep 2f4d -A
"GC task thread#0 (ParallelGC)" os_prio= tid=0x00007f223405e000 nid=0x2f4d runnable "GC task thread#1 (ParallelGC)" os_prio= tid=0x00007f2234060000 nid=0x2f4e runnable "GC task thread#2 (ParallelGC)" os_prio= tid=0x00007f2234061800 nid=0x2f4f runnable "GC task thread#3 (ParallelGC)" os_prio= tid=0x00007f2234063800 nid=0x2f50 runnable "VM Periodic Task Thread" os_prio= tid=0x00007f22341ed800 nid=0x2f59 waiting on condition JNI global references: [root@iZwz9gs2zseivevv1k5vnkZ syp]# jstack | grep 2f4e -A
"GC task thread#1 (ParallelGC)" os_prio= tid=0x00007f2234060000 nid=0x2f4e runnable "GC task thread#2 (ParallelGC)" os_prio= tid=0x00007f2234061800 nid=0x2f4f runnable "GC task thread#3 (ParallelGC)" os_prio= tid=0x00007f2234063800 nid=0x2f50 runnable "VM Periodic Task Thread" os_prio= tid=0x00007f22341ed800 nid=0x2f59 waiting on condition JNI global references: "GC task thread#2 (ParallelGC)" os_prio= tid=0x00007f2234061800 nid=0x2f4f runnable "GC task thread#3 (ParallelGC)" os_prio= tid=0x00007f2234063800 nid=0x2f50 runnable "VM Periodic Task Thread" os_prio= tid=0x00007f22341ed800 nid=0x2f59 waiting on condition JNI global references: [root@iZwz9gs2zseivevv1k5vnkZ syp]# jstack | grep 2f50 -A
"GC task thread#3 (ParallelGC)" os_prio= tid=0x00007f2234063800 nid=0x2f50 runnable "VM Periodic Task Thread" os_prio= tid=0x00007f22341ed800 nid=0x2f59 waiting on condition JNI global references:
参考:
https://blog.csdn.net/moranzi1/article/details/89341480
java进程CPU高分析的更多相关文章
- JAVA进程CPU高的解决方法
无限循环的while会导致CPU使用率飙升吗?经常使用Young GC会导致CPU占用率飙升吗?具有大量线程的应用程序的CPU使用率是否较高?CPU使用率高的应用程序的线程数是多少?处于BLOCKED ...
- Linux下java进程CPU占用率高分析方法
Linux下java进程CPU占用率高分析方法 在工作当中,肯定会遇到由代码所导致的高CPU耗用以及内存溢出的情况.这种情况发生时,我们怎么去找出原因并解决. 一般解决方法是通过top命令找出消耗资源 ...
- (转)Linux下java进程CPU占用率高-分析方法
Linux下java进程CPU占用率高-分析方法 原文:http://itindex.net/detail/47420-linux-java-%E8%BF%9B%E7%A8%8B?utm_source ...
- Linux下java进程CPU占用率高分析方法(一)
Linux下java进程CPU占用率高分析方法 在工作当中,肯定会遇到由代码所导致的高CPU耗用以及内存溢出的情况.这种情况发生时,我们怎么去找出原因并解决. 一般解决方法是通过top命令找出消耗资源 ...
- Linux下java进程CPU占用率高-分析方法
今天登陆同事的一台gateway 开始以为hive环境登陆不了了,仔细一看看了下是因为机器很卡,我每次等几秒没登陆就ctrl+c了,看了下是有个java进程cpu:340.4% mem:14.6% ...
- Java进程CPU使用率高排查
Java进程CPU使用率高排查 生产java应用,CPU使用率一直很高,经常达到100%,通过以下步骤完美解决,分享一下.1.jps 获取Java进程的PID.2.jstack pid >> ...
- 排查java进程cpu占用高的问题
一.思路 分两步,主要是找出占用cpu高的进程,再找出该进程内到底是哪个线程占用cpu高. 二.找出占用cpu高的进程 参考: https://blog.csdn.net/hfhwfw/article ...
- java问题排查工具之一板斧jstack——使用 jstack 定位 java进程CPU过高的问题
jstack主要用来查看某个Java进程内的线程堆栈信息.语法格式如下: jstack [option] pid jstack [option] executable core jstack [opt ...
- Linux 下定位java应用 cpu高的原因(转)
使用场景: 遇到Linux下java应用cpu占用很高的时候,我们很想知道此时的应用到底在做什么导致资源的消耗. 方便我们进一步定位和优化~ 1.查询cpu耗用top5的进程(你也可以top10) [ ...
随机推荐
- Windows环境安装MySQL8.0.11
网络开发数据库是必不可少的.曾经安装个Mysql,但是忘了.再次安装还是得百度.那还不如自己写篇博客记录一下呢,以后再忘记就看自己的博客好 Mysql官网安装地址(windows环境): https: ...
- github pr
github----向开源框架提交pr的过程 https://blog.csdn.net/vim_wj/article/details/78300239github 的 pr 使用方法 https:/ ...
- mysql 首次安装后 简单操作与语句 新手入门
首先cd到安装目录中bin路径:这是我的安装路径以管理员身份打开cmd(防止权限不足)cd E:\>cd E:\mysql\mysql-5.5.40-winx64\bin 首次安装需要输入 my ...
- ubuntu下如何安装linaro工具链?
1. 获取工具链 从此处获取,如: wget https://releases.linaro.org/components/toolchain/binaries/7.3-2018.05/aarch64 ...
- [z]curl使用指南
https://www.jianshu.com/p/fc0eb6c60816 curl -X POST "http://aa/bb/cc" -H "accept:*/* ...
- 使用Selenium时解决方案: Exception: Failed to find firefox binary. You can set it by specifying the ······
问题描述: Firefox在自动升级之后,在使用selenium的时候出现了如下错误: Exception: Failed to find firefox binary. You can set it ...
- 一百零六:CMS系统之修改邮箱功能完成
这里采用把验证码放到memcached中,所以封装一个memcached的操作 import memcache cache = memcache.Client(['127.0.0.1:11211'], ...
- pod installation failed with react native 0.44
今天在集成react-native-sqlite-storage组件CocoaPods的时候遇到以下错误,这里记录一下错误解决方法: 报错如下: 以为是我Cocoapods的版本问题,于是更新版本: ...
- bootstrap4 调整元素之间距离
影响元素之间的间距是可以通过style的margin或padding属性来实现,但这两个属性本意并不相同:margin影响的是本元素与相邻外界元素之间的距离,这里简称外边距:padding影响的元素本 ...
- 【JulyEdu-Python基础】第 7 课:Python并发编程以及系统常用模块
主要内容 Python多进程与多线程 Python使用Hadoop分布式计算库mrjob Python使用Spark分布式计算库PySpark 例子:分别使用MapReduce和Spark实现word ...