虚引用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时进行清理。
🏷️
标签
➡️