我有一个Linux守护程序,该守护程序派生了几个 child 并监视它们的崩溃(根据需要重新启动)。
如果父级可以监视子进程的内存使用情况,则可以很好-检测内存泄漏并在超出一定大小时重新启动子进程。
我怎样才能做到这一点?
最佳答案
您应该能够从/proc/{PID}/status中获取详细的内存信息:
Name: bash
State: S (sleeping)
Tgid: 6053
Pid: 6053
PPid: 6050
TracerPid: 0
Uid: 1007 1007 1007 1007
Gid: 1007 1007 1007 1007
FDSize: 256
Groups: 1007
VmPeak: 48076 kB
VmSize: 48044 kB
VmLck: 0 kB
VmHWM: 4932 kB
VmRSS: 2812 kB
VmData: 2232 kB
VmStk: 84 kB
VmExe: 832 kB
VmLib: 6468 kB
VmPTE: 108 kB
Threads: 1
SigQ: 0/8190
SigPnd: 0000000000000000
ShdPnd: 0000000000000000
SigBlk: 0000000000000000
SigIgn: 0000000000001010
SigCgt: 0000000188020001
CapInh: 0000000000000000
CapPrm: 0000000000000000
CapEff: 0000000000000000
Cpus_allowed: 0f
Mems_allowed: 00000000,00000001
voluntary_ctxt_switches: 69227121
nonvoluntary_ctxt_switches: 19071
但是,除非出现严重的内存泄漏,否则很难从进程统计信息中检测到它们,因为malloc和free通常是从它们所对应的系统调用(brk/sbrk)中抽象出来的。
您还可以检入/proc/$ {PID}/statm。
关于c - 监视子进程的内存使用情况,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/2754237/