jdk1.8 ConcurrentHashMap computeIfAbsent 死循环

本文记录了一次线上CPU飙升至100%的故障排查经历。故障原因为使用computeIfAbsent方法时,在特定条件下形成了死循环。文章详细介绍了如何通过SQL排查、代码审查及jstack线程分析定位问题。

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

根因:调用 computeIfAbsent 方法时,嵌套调用computeIfAbsent时,如果key的hashCode相同,逻辑中会产生死循环。

现象:

某天发布后,线上cpu飙到100%,线上DB大量大事务无法结束。我们作为底层应用,需要快速解决问题。当时就保留了线程展,然后重启应用,重启后一段时间又出现相同现象,推测是刚发布代码的问题,立即回滚代码。故障恢复。

排查:

1. 逐一排查 线上大事务的sql,寻找规律。

2. 逐行排查发布的代码

3. 分析jstack的线程栈

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值