当前位置: 首页 > ai >正文

Font导致内存泄漏问题排查记录

事件伊始

线上监控告警,某服务进程占用内存超过9G。该服务使用docker运行,且启动命令设置-Xmx为2G。
系统负载内存占用
启动参数
查看GC记录,计算堆内存大小正常
GC堆内存记录
查看内存块
pmap内存信息
判断为内存泄漏问题。

找到问题

使用jmap dump出hprof文件,使用MAT打开进行分析,直接提示潜在内存泄漏问题
MAT
系统中会使用到Font相关的就很快定位到是一个给图片加水印的功能,直接定位到具体方法了。
同时,搜索互联网相关文档信息,找到类似记录:

  1. 记一次Font导致JVM堆外内存泄漏分析
  2. Java使用Font字体的方法

测试环境复现

在测试环境设置docker容器最大可用500M,压测对应接口,持续一段时间后出现无法分配内存错误,容器重启。现象是,开始时每次内存占用接近500M的时候,会进行FullGC, 内存清理后又从400多兆开始慢慢增加。最后到报无法分配内存的时候重启。
容器重启
查看系统日志,已经能够直接定位到代码:
异常栈
再将测试环境docker容器可用内存设置为2G,设置java启动参数-Xmx500M, 压测接口,复现了生产的场景:
测试环境复现

修改代码复测

原代码中,每次请求进入方法,都会使用FontUtil.createFont(resource.getInputStream())创建新的Font对象,修改为使用单例模式,使Font对象为全局唯一,只加载一次。
修改后发布到测试环境再次压测,持续进行较长时间,内存占用稳定,GC次数正常,判断问题解决
请添加图片描述

http://www.xdnf.cn/news/6566.html

相关文章:

  • Android 中 打开文件选择器(ACTION_OPEN_DOCUMENT )
  • 利用边缘计算和工业计算机实现智能视频分析
  • JAVAfx项目总结 算法题
  • 《AI大模型应知应会100篇》第65篇:基于大模型的文档问答系统实现
  • Linux 系统切换国内镜像源教程
  • ChatGPT到Claude全适配:跨模型Prompt高级设计规范与迁移技巧
  • 面向SDV的在环测试深度解析——仿真中间件SIL KIT应用篇
  • 职坐标AIoT技能培训课程实战解析
  • python报错:必须实现所有abstract方法原因及解决方案
  • 如何更改远程桌面连接的默认端口?附外网访问内网计算机方法
  • 数学复习笔记 13
  • polarctf-web-[rce1]
  • P1439 【模板】最长公共子序列
  • 第五部分:第五节 - Express 路由与中间件进阶:厨房的分工与异常处理
  • “多维像素”可赋能具身智能非凡感知力——昱感微参加2025松山湖中国IC创新高峰论坛
  • 2026《数据结构》考研复习笔记四(绪论)
  • [AI算法] LLM训练-构建transformers custom model
  • 安卓中0dp和match_parent区别
  • Verilog HDL 语言整理
  • Vue.js教学第二章:Vue实例创建与核心选项全解析
  • 「Mac畅玩AIGC与多模态40」开发篇35 - 用 Python 开发服务对接 SearxNG 与本地知识库
  • C++(16):“”符号
  • 【ARM】MDK如何将变量存储到指定内存地址
  • GESP2025年3月认证C++二级( 第三部分编程题(1)等差矩阵)
  • conda创建环境常用命令(个人用)
  • 优雅使用Gunicorn进程管理FastAPI
  • 硬件厂商的MIB文档详解 | 如何查询OID? | MIB Browser实战指南-优雅草卓伊凡
  • 基于MATLAB-GUI图形界面的数字图像处理
  • 深入理解For循环及相关关键字原理:以Python和C语言为例
  • uni-app x正式支持鸿蒙原生应用开发