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

线上阿里云的服务器出现了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、修改后重新查看系统运行情况,已经正常。
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

MonkeyKing.sun

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

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

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

打赏作者

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

抵扣说明:

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

余额充值