K8S容器POD内存快照导出分析处理方案

1. 获取K8S容器POD内存快照

复制代码
# 进入k8s pod
kubectl  exec  -it   POD_NAME   -n  POD_NAMESPACE  --   /bin/sh

# 获取java进程PID
ps   -ef  |   grep  java

# 生成堆快照
jmap -dump:live,format=b,file=test_app_heap.hprof  PID

# 查看堆概要
jmap -heap PID

# 统计前10个内存消耗对象
jmap -histo:live  PID | head -n 10

# 复制pod堆快照文件到宿主机
kubectl   cp  POD_NAMESPACE/POD_NAME:/example_pod/test_app_heap.hprof  test_app_heap.hprof

2. 分析工具

2.1 VisualVM

  1. JDK 自带的图形化工具(建议从官网下载最新版以兼容更多功能)。

  2. 操作步骤:

    ① 打开VisualVM → 点击 File > Load → 选择堆转储文件(如.hprof);

    ② 在 "Heap Dump" 标签页查看整体内存分布(对象数量、占用大小);

    ③ 切换到 "Objects" 视图 → 按占用空间排序(Size降序);

    ④ 选中可疑对象 → 右键 "Show in GC Root Path" → 追踪其GC引用链,定位持有大内存的对象及其引用源。

2.2 Memory Analyzer (MAT)

  1. Eclipse基金会开发的深度内存分析工具(推荐处理大型堆转储)。

  2. 支持检测内存泄漏(如通过 Leak Suspects Report 自动生成泄漏报告);

  3. 提供对象依赖树(Dominator Tree)视图,识别内存瓶颈的关键对象。

相关推荐
lichenyang45337 分钟前
Docker 学习笔记(四):Dockerfile,把项目打成自己的镜像
docker·容器
lichenyang45341 分钟前
Docker 学习笔记(三):Docker 网络、bridge、子网和容器互通
docker·容器
lichenyang45344 分钟前
Docker 学习笔记(二):docker run 的参数到底在控制什么?
docker·容器
阿里云云原生17 小时前
香港站【企业 AI Agent 工程化实战专场】来啦,邀您7月9日见!
云原生·agent
阿里云云原生20 小时前
研发域与运维域的“数字握手”:通过 Agentic Skills 实现 DevOps 全链路自动化
云原生
运维开发故事3 天前
基于 Arthas 的多集群在线诊断系统设计与实现
kubernetes
Patrick_Wilson5 天前
从「改个端口」到 502:Next.js on k8s 的容器端口、Service 映射与 env 覆盖
docker·kubernetes·next.js
阿里云云原生5 天前
AI 开发新常态:当 Cursor、Claude、Codex 并行,如何统一管理散落的 Skill 资产?
云原生·ai编程
探索云原生5 天前
K8s 1.36 这个 GA 特性,把 initContainer 拉模型的 hack 干掉了
ai·云原生·kubernetes
云恒要逆袭5 天前
运行你的第一个Docker容器
后端·docker·容器