一、 ps -ef|grep flink 和 top -p pid 组合

Linux下查看某一个进程所占用的内存,首先可以通过ps命令找到进程id,比如:ps -ef|grep flink,可以看到flink task这个程序的进程id

已知pid是8678,现在可以使用如下命令查看内存:

 这样可以动态实时的看到CPU和内存的占用率,然后按q键回到命令行

二、直接命令查看 ps -aux|grep flink

 第一个标注的地方是CPU和内存占用率,后面的15 209 056是物理内存使用量,单位是k,此时kafka大约占用15G内存

 

1)USER: 行程拥有者
2)PID: 进程的ID
3)%CPU: 占用的 CPU 使用率
4)%MEM: 占用的记忆体使用率
5)VSZ: 占用的虚拟记忆体大小
6)RSS: 占用的记忆体大小
7)TTY: 终端的次要装置号码 (minor device number of tty)
8)STAT: 该行程的状态:
        D: 不可中断的静止
        R: 正在执行中
        S: 静止状态
        T: 暂停执行
        Z: 不存在但暂时无法消除
        W: 没有足够的记忆体分页可分配
        <: 高优先序的行程
        N: 低优先序的行程
        L: 有记忆体分页分配并锁在记忆体内
9)START: 行程开始时间
10)TIME: 执行的时间
11)COMMAND:所执行的指令

ps aux|sort -k4,4nr|head -n 10 查看内存占用前10名的程序 

 三、查看进程文件cat /proc/pid/status

比如:cat /proc/8678/status

VmSize对应的值就是物理内存占用,大约为943M和刚才一致

 

在这里我们关注VmSize|VmRSS|VmData|VmStk|VmExe|VmLib 这个6个指标,下面有一些简单的解释。

  1. VmSize:  虚拟内存大小。 整个进程使用虚拟内存大小,是VmLib, VmExe, VmData, 和 VmStk的总和。占所有虚拟内存分配(文件映射,共享内存,堆内存,任何内存)的份额,并且几乎在每次分配新内存时都会增长。几乎,因为如果在数据段中用新的堆内存分配代替了释放的旧分配,则不会分配新的虚拟内存。每当释放虚拟分配时,它都会减少。VmPeak跟踪的最大值VmSize-只能随时间增加。
  2. VmLck:  虚拟内存锁。进程当前使用的并且加锁的虚拟内存总数
  3. VmRSS:  虚拟内存驻留集合大小。这是驻留在物理内存的一部分。它没有交换到硬盘。它包括代码,数据和栈。随着访问内存的增加而增加,随着将页面调出到交换设备的次数减少。
  4. VmData:  虚拟内存数据。堆使用的虚拟内存。随着使用堆的数据段部分而增长。由于当前的堆分配器会保留释放的内存,以防将来的分配需要它,它几乎永远不会收缩。
  5. VmStk: 虚拟内存栈。栈使用的虚拟内存
  6. VmExe: 可执行的虚拟内存,可执行的和静态链接库所使用的虚拟内存
  7. VmLib: 虚拟内存库,动态链接库所使用的虚拟内存

补充:

  1. VmPeak代表当前进程运行过程中占用内存的峰值.
  2. VmSize代表虚拟内存总大小
  3. VmLck代表进程已经锁住的物理内存的大小.锁住的物理内存不能交换到硬盘.
  4. VmHWM是程序得到分配到物理内存的峰值.
  5. VmRSS是程序现在使用的物理内存.
  6. VmData:表示进程数据段的大小.
  7. VmStk:表示进程堆栈段的大小.
  8. VmExe:表示进程代码的大小.
  9. VmLib:表示进程所使用LIB库的大小.
  10. VmPTE:占用的页表的大小.
  11. VmSwap:进程占用Swap的大小.
  12. Threads:表示当前进程组的线程数量.
  13. SigPnd:屏蔽位,存储了该线程的待处理信号,等同于线程的PENDING信号.
  14. ShnPnd:屏蔽位,存储了该线程组的待处理信号.等同于进程组的PENDING信号.
  15. SigBlk:存放被阻塞的信号,等同于BLOCKED信号.
  16. SigIgn:存放被忽略的信号,等同于IGNORED信号.
  17. SigCgt:存放捕获的信号,等同于CAUGHT信号.
  18. CapEff:当一个进程要进行某个特权操作时,操作系统会检查cap_effective的对应位是否有效,而不再是检查进程的有效UID是否为0.
  19. CapPrm:表示进程能够使用的能力,在cap_permitted中可以包含cap_effective中没有的能力,这些能力是被进程自己临时放弃的,也可以说cap_effective是cap_permitted的一个子集.
  20. CapInh:表示能够被当前进程执行的程序继承的能力.
  21. CapBnd:是系统的边界能力,我们无法改变它.
  22. Cpus_allowed:3指出该进程可以使用CPU的亲和性掩码,因为我们指定为两块CPU,所以这里就是3,如果该进程指定为4个CPU(如果有话),这里就是F(1111).
  23. Cpus_allowed_list:0-1指出该进程可以使用CPU的列表,这里是0-1.
  24. voluntary_ctxt_switches表示进程主动切换的次数.
  25. nonvoluntary_ctxt_switches表示进程被动切换的次数.
     

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐