1、查看命名空间里面的pod:kubectl get pod -n semir-r3-ic

[root@iZ8vb3cdhd9ya95340p0jdZ kubernetes]# kubectl get pod -n semir-r3-ic

NAME READY STATUS RESTARTS AGE 
jck-deployment-yacs-25028-25990-2543089-579f5b4846-7ct2n 1/1 Running 12 20h 
jck-deployment-yacs-25028-25990-2543089-579f5b4846-9wdm8 1/1 Running 10 20h 
jck-deployment-yacs-25028-25990-2543089-579f5b4846-f7gdd 1/1 Running 10 20h 
jck-deployment-yacs-25028-25990-2543089-579f5b4846-fs4wb 1/1 Running 11 20h

2、查看某个pod的事件:kubectl describe pod -n 名称空间

kubectl describe pod jck-deployment-yacs-25028-25990-2543089-579f5b4846-9wdm8 -n semir-r3-ic

3、查看某个pod里面进程状态:/proc/[pid]/status

通过 /proc/[pid]/status 文件,可以查看进程的某些状态信息,其中包括了内存占用情况。其中 [pid] 是进程 ID,可以通过 ps 命令或 top 命令等获得。

在 status 文件中可以找到以下两行信息:

VmRSS: 123456 kB VmSize: 789012 kB

其中:

  • VmSize 表示进程虚拟内存的使用情况,单位是 KB。它包括进程使用的内存总和,包括实际使用的物理内存、虚拟内存、共享内存、库文件等。
  • VmRSS 表示进程实际使用的物理内存的情况,单位也是 KB。它只包括进程使用的实际物理内存。

23 进程为例,可以通过以下命令查看其内存占用情况:

cat /proc/23/status | grep Vm

输出结果会包含 VmRSS 和 VmSize 行的信息。其中,VmRSS 行的值会比 VmSize 行的值小,因为它只包括实际使用的物理内存。

4、查看某个pod里面进程GC情况:jstat -gc 32

5、查看某个pod里面进程对应的资源对象和类的占比关系:jmap -histo pid | head -20

7、dump java堆数据

sudo -u tomcat jmap -dump:live,format=b,file=/dump201612271310.dat 384// 获取所有对象的dumpjmap -dump:format=b,file=/tmp/heap.hprof // 获取存活对象的dump,实际效果是先执行一次FULL GCjmap -dump:live,format=b,file=/tmp/heap-live.hprof

heap dump会造成JVM比较长时间的停顿,必须摘流量执行

dump文件一定要zip后再传输,能节约大量传输时间

tar -zcf /tmp/heap.hprof.gz /tmp/heap.hprof

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐