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

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

内容提要

由于大量PhantomReference对象导致GC耗时增加,系统出现超时告警。通过优化数据库连接池配置和定期清理虚引用,GC停顿时间显著降低,系统恢复正常,超时告警消失。

🎯

关键要点

  • 线上应用频繁出现超时告警,主要是由于getUiToken接口异常状态码导致的。

  • 服务器配置为Linux 4c8g,JVM参数配置包括使用G1GC和HeapDump等。

  • 通过SGM监控平台分析接口耗时,发现GC处理时间过长是主要原因。

  • GC日志显示PhantomReference对象数量过多,导致GC停顿时间增加。

  • PhantomReference是最弱的引用关系,主要用于对象被回收时的通知。

  • 通过内存分析工具MAT发现有4340个虚引用对象,主要是ConnectionPhantomReference。

  • 数据库连接池的默认配置导致频繁创建新连接,增加了PhantomReference数量。

  • 优化方案包括调整连接池配置和增加连接存活时间,减少新连接生成。

  • 开启ref-proc并行处理以提高GC效率。

  • 定时清理虚引用列表数据或升级mysql-connector-java版本作为解决方案。

  • 优化后GC停顿时间显著降低,系统恢复正常,超时告警消失。

延伸问答

GC耗时增加的主要原因是什么?

GC耗时增加主要是由于PhantomReference对象数量过多,导致GC停顿时间增加。

如何优化GC停顿时间?

通过优化数据库连接池配置和定期清理虚引用,可以显著降低GC停顿时间。

PhantomReference是什么?

PhantomReference是最弱的引用关系,用于在对象被回收时接收通知。

优化后GC停顿时间的变化如何?

优化后GC最大停顿时间由1.25秒降低至0.1秒,young GC频率从20秒一次优化到6分钟一次。

为什么会有大量ConnectionPhantomReference对象?

大量ConnectionPhantomReference对象是由于数据库连接池的默认配置导致频繁创建新连接。

如何定期清理虚引用?

可以通过定时任务定期清理虚引用列表数据,设置条件如数量超过500时进行清理。

➡️

继续阅读