V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
sdbybyd
V2EX  ›  Java

请教下 k8s 下 Java 内存泄露定位问题

  •  
  •   sdbybyd · 2020-11-07 15:42:26 +08:00 · 2812 次点击
    这是一个创建于 1258 天前的主题,其中的信息可能已经有所发展或是发生改变。

    请教下大家,k8s 下定位 java 内存泄露有没好方法呢?或者什么工具软件可以使用

    7 条回复    2020-11-08 17:42:52 +08:00
    tomsun28
        1
    tomsun28  
       2020-11-07 16:40:21 +08:00
    kubectl logs -p podName
    sdbybyd
        2
    sdbybyd  
    OP
       2020-11-07 16:43:38 +08:00
    @tomsun28 这个只能看日志啊
    hasdream
        3
    hasdream  
       2020-11-07 17:32:59 +08:00 via Android
    进容器 jmap dump 内存 用 mta 分析 😊😊
    dreamusername
        4
    dreamusername  
       2020-11-07 18:39:31 +08:00
    前提是你的 java 不可以使用 pid 1 启动,因为当 java 在 pid 启动的时候,是没有办法使用任何工具 dump 内存,解决方案是把 entrypoint 换成 tini 。
    其次才是 dump 内存,这个可以尝试下 arthas
    ica10888
        5
    ica10888  
       2020-11-08 16:40:28 +08:00
    jmap jstat,前提是你的基础 dockerfile 里面包含了 java tools 。如果没有,就用一个含有 java tools 的 ephemeral container 去 jmap jstat 那个 pod 的进程
    ica10888
        6
    ica10888  
       2020-11-08 16:42:32 +08:00
    阿里巴巴的 arthas 也是不错工具
    julyclyde
        7
    julyclyde  
       2020-11-08 17:42:52 +08:00
    @dreamusername 为什么 1 号 pid 不能 dump 内存?
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   5486 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 01:39 · PVG 09:39 · LAX 18:39 · JFK 21:39
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.