java 高cpu占用问题解决

这是一次真实的问题解决,献给同样被高cpu问题困扰的大家。

背景:

      某天内部用户反馈,前端界面加载特别慢。测试了网络,日志,代码,感觉都正常,但是程序在使用查询sql的时候就是不返回。

1、进到linux容器中执行 top命令,结果发现高cpu占用,其中pid 为1的正是我们的java程序

2、执行命令找出占用CPU最高的线程   top -Hp  pid   显示的新pid都是线程,找到占用cpu最高的线程号  

3、把线程号转换为16进制,便于在jstack中查询   printf "%x\n" tid   变为16进制

4、jstack命令查看相应线程的堆栈    jstack pid | grep 0x十六进制结果  -A30

5、定位到代码,是同事写的一个死循环,通过mybits一直循环查询mysql是否有值,如果有值跳出循环,但是mybits有一级缓存,通过去掉一级缓存解决问题
 

<setting name="localCacheScope" value="SESSION"/>

改为<setting name="localCacheScope" value="STATEMENT"/>解决

ps:高cpu通常伴随着死循环,可以重点往这方面想。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

一杯咖啡半杯糖

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值