最近一个应用出现了cpu升高到100%的问题,一直没有解决掉

根据常见的top  -Hp等思路发现占用cpu较高的几个pid 都是正常业务,

不过当时也看到有属于内存回收的进程占用的cpu非常高,但是很快就没有了, 当时没太注意

 

后来还改了程序的一个实现方式,因为修改了cat的源码,当时以为改坏了,目前看只靠猜测是不靠谱的

修改了实现方式还是不行 还是几天后会cpu100%

处理步骤:

1今天还是利用jstack pid打出了应用的线程栈信息 发现线程数非常多 

tomcat启动了7000左右的线程 

查看某个应用pid下面的线程数

ps -Lf 10090|wc -l     (10090为某个应用的pid)

 

2查看当前tomcat的jvm的配置发现 Xms Xmx都是2g 服务器总共4g

top看到tomcat使用内存已经是2.7g 

使用命令查看gc情况 

CPU异常 java javacpu过高是什么原因_内存回收

有点慌  12天运行fullgc 13827次 年老代一直100% fullgc没效果了 内存不够

当然这个使用内存(和占用cpu 和线程数)都是慢慢爬上去的,所以一开始有可能几天看不出来这个问题

(参数的解释可以看这里 )

 

解决办法 在4g 总内存的情况下 调整jvm 参数

-Xms3460m -Xmx3460m -Xss256K -XX:NewSize=1724m -XX:MaxNewSize=1724m

  

Xss默认是1m 由于这个项目使用线程数很多 设置为较小值 比较合适,新时代 年老代都调大.

目前测试环境还在观察 效果

-----------

测试一天发现还是有问题 提高内存 减小线程大小从根本上解决不了问题 

因为线程数还在上升,慢慢把内存占满最后发现是cat引入了一个依赖包 有问题,

 

最后cpu100%的问题还是回归 top -Hp  以及查找具体的线程 定位具体的线程栈信息 

如果定位到自己项目的方法 基本就是问题所在

如果是底层的代码,可能是这个底层代码出问题了 看看依赖是否正确

或者拿掉。或者寻找替换品,或者版本是否正确