线上机器CPU占用高分析实践
💡
原文中文,约2400字,阅读约需6分钟。
📝
内容提要
本文分析了线程的两种状态:WAITING和TIMED_WAITING。WAITING状态表示线程在等待特定操作,而TIMED_WAITING状态则是在指定时间内等待条件。通过代码分析,发现并发任务存在性能问题,建议优化线程池逻辑和异常处理,以减少CPU资源浪费。
🎯
关键要点
- 本文分析了线程的两种状态:WAITING和TIMED_WAITING。
- WAITING状态表示线程在等待特定操作,不会继续执行。
- TIMED_WAITING状态表示线程在指定时间内等待条件,超时后自动返回。
- 线程进入WAITING状态的常见情况包括调用Object.wait()、Thread.join()和LockSupport.park()。
- 线程进入TIMED_WAITING状态的常见情况包括调用Thread.sleep()、Object.wait()和Thread.join()。
- 在实际代码中,发现并发任务存在性能问题,建议优化线程池逻辑和异常处理。
- 火焰图分析显示多次的stream调用导致CPU资源浪费,建议将toMap逻辑提到循环外。
- 优化建议包括取消超时线程的执行,减少CPU资源浪费。
- 观察到queryActTp处于WAITING状态可能是由于执行未取消,需进一步分析原因。
❓
延伸问答
什么是WAITING状态?
WAITING状态表示线程在等待另一个线程的特定操作,不会继续执行,直到被通知或中断。
TIMED_WAITING状态与WAITING状态有什么区别?
TIMED_WAITING状态是线程在等待某个条件的发生,但会在指定时间后自动返回,而WAITING状态则不会自动返回。
如何优化线程池逻辑以减少CPU资源浪费?
建议取消超时线程的执行,并将多次的stream调用优化,将toMap逻辑提到循环外。
线程进入WAITING状态的常见情况有哪些?
常见情况包括调用Object.wait()、Thread.join()和LockSupport.park()。
在实际代码中发现了哪些性能问题?
发现并发任务存在性能问题,尤其是CPU频繁切换导致的压力。
如何恢复TIMED_WAITING状态的线程?
TIMED_WAITING状态的线程会在指定时间结束后自动恢复,或在其他线程调用notify()或notifyAll()时恢复。
➡️