标题: 无法回收的僵尸进程
https://scz.617.cn/unix/201511041359.txt
zyh 2015-11-04 13:59
通常情况下父进程结束后,僵尸进程会被init回收。但是可能出现以下情况:
ps -elf
F S UID PID PPID C PRI NI ADDR SZ WCHAN STIME TTY TIME CMD
...
0 Z test 2885 1 0 80 0 - 0 exit Aug11 ? 00:10:38 [adb]
...
2885的父进程已经是init,但它仍保持为僵尸进程。这是因为该进程还有一个内核态
的线程:
ps aumx
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
...
test 2885 0.0 0.0 0 0 ? - Aug11 10:38 [adb]
test - 0.0 - - - - Zl Aug11 0:00 -
test - 0.0 - - - - Dl Aug11 10:38 -
...
STAT列的Dl表示"uninterruptible sleep state",这个线程等待在内核态,并且不
接受任何中断,包括SIGKILL。
用"magic SysRq key"可以看到线程的调用栈:
echo "1" > /proc/sys/kernel/sysrq
echo 'w' > /proc/sysrq-trigger
dmesg
...
[7369283.509835] Call Trace:
[7369283.509837] [] schedule+0x3f/0x60
[7369283.509840] [] rpm_resume+0x17e/0x690
[7369283.509842] [] ? add_wait_queue+0x60/0x60
[7369283.509844] [] __pm_runtime_resume+0x5c/0x90
[7369283.509847] [] usb_autoresume_device+0x29/0x60
[7369283.509849] [] usbdev_open+0x11b/0x250
[7369283.509852] [] chrdev_open+0xd9/0x250
[7369283.509854] [] __dentry_open+0x2b0/0x380
[7369283.509856] [] ? cdev_put+0x30/0x30
[7369283.509859] [] ? security_inode_permission+0x1c/0x30
[7369283.509862] [] ? inode_permission+0x4a/0x110
[7369283.509863] [] vfs_open+0x3d/0x40
[7369283.509865] [] nameidata_to_filp+0x40/0x50
[7369283.509867] [] do_last+0x3f8/0x730
[7369283.509869] [] path_openat+0xd1/0x3f0
[7369283.509871] [] ? lock_hrtimer_base.isra.24+0x30/0x60
[7369283.509873] [] ? hrtimer_try_to_cancel+0x50/0xc0
[7369283.509876] [] do_filp_open+0x42/0xa0
[7369283.509878] [] ? strncpy_from_user+0x31/0x40
[7369283.509880] [] ? do_getname+0x10a/0x180
[7369283.509882] [] ? _raw_spin_lock+0xe/0x20
[7369283.509885] [] ? alloc_fd+0xf7/0x150
[7369283.509886] [] do_sys_open+0xf8/0x240
[7369283.509889] [] compat_sys_open+0x1a/0x20
[7369283.509891] [] sysenter_dispatch+0x7/0x2e
...
这里似乎在等待某个USB设备上的文件,然而本机并未接入USB存储设备。所以,能做
的只有重启了。