线上机器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()时恢复。

➡️

继续阅读