排查线上CPU过高的问题,阿里云提供的命令java -jar arthas-boot.jar

本文介绍了一种解决阿里云服务器CPU过高的方法。通过分析发现是由于Tomcat服务中的特定线程导致CPU占用率高,进而影响了服务响应速度。通过调整JVM参数优化了内存分配,最终解决了问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

线上阿里云的服务器出现了CPU过高,如下图所示:
在这里插入图片描述
各个服务的接口服务响应时间超过了4秒,整个服务的体验非常的差。
1、top命令显示PID为22800的java进程占用的cpu资源过高。

2、使用 ps -ef | grep 22800 命令,查看到这是一个tomcat服务,找到具体的目录,我的服务的路径为/home/tomcat/tomcat6/9601_timerbackend。

3、进入tomcat目录底下,cd /home/tomcat/tomcat6/9601_timerbackend,执行命令
java -jar arthas-boot.jar
注意本条命令,只有阿里云服务器才有,其他云服务器需要安装。
选择具体的进程,在后面的序号中输入自己的编号。我这边输入的是1
4、
5、当看到ARTHAS时,输入dashboard 命令,如下图所示

在这里插入图片描述
看到C2 CompilerThread1,C2 CompilerThread2,C2 CompilerThread0 三个线程占用内存非常高。

6、使用thread -1 命令,查看都是什么线程造成的cpu使用过高。
在这里插入图片描述
7、查看tomcat的jvm配置,使用jps,查看所有的进程,
在这里插入图片描述
然后使用jmap -heap 10444,查看到内存分配,可以使用free -m 查看自己机器的内存,整个jvm的分配不是越大越好。
在这里插入图片描述
7、修改后的jvm的配置参数如下:

JAVA_OPTS='-server -Xmn4g -Xms8g -Xmx8g -Xss512K -XX:+AggressiveOpts -XX:+UseBiasedLocking -XX:+DisableExplicitGC -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSParallelRemarkEnabled -XX:+UseCMSCompactAtFullCollection -XX:+UseFastAccessorMethods -XX:+UseCMSInitiatingOccupancyOnly -XX:PermSize=1g -XX:MaxPermSize=1g'

8、修改后重新查看系统运行情况,已经正常。
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

MonkeyKing.sun

对你有帮助的话,可以打赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值