虚引用GC耗时分析优化(由 1.2 降低至 0.1 秒)

💡 原文中文,约8400字,阅读约需20分钟。
📝

内容提要

线上应用出现超时告警,分析发现getUiToken接口的GC处理时间过长,主要由于大量PhantomReference对象。通过优化数据库连接池配置和开启并行处理,GC时间显著降低,系统响应恢复正常,超时告警消失。

🎯

关键要点

  • 线上应用频繁出现超时告警,主要是getUiToken接口的GC处理时间过长。
  • GC处理时间过长的原因是大量PhantomReference对象。
  • 通过优化数据库连接池配置和开启并行处理,GC时间显著降低。
  • 优化后,系统响应恢复正常,超时告警消失。
  • 分析发现getUiToken接口的业务逻辑简单,没有复杂操作。
  • GC日志显示young gc频率高,且处理PhantomReference耗时长。
  • PhantomReference是最弱的引用关系,主要用于对象被回收时的通知。
  • ConnectionPhantomReference对象数量过多是由于数据库连接未显式关闭。
  • 优化建议包括调整连接池配置和开启ref-proc并行处理。
  • 定时任务可用于清理虚引用列表,避免GC时间过长。
  • 优化后GC时间最大停顿时间由1.25秒降至0.1秒,系统响应正常。
➡️

继续阅读