Zombie程序

为当前最终发行版之前的所有版本提供支持
头像
vcxzfdsarewq
帖子: 92
注册时间: 2007-04-20 18:22
来自: Matrix
送出感谢: 0
接收感谢: 0

Zombie程序

#1

帖子 vcxzfdsarewq » 2007-08-01 11:04

今天top时有两个Zombie程序
kill不掉,是scim和netstat
我的scim还是能输入的
请高手指点一下
头像
eexpress
帖子: 58428
注册时间: 2005-08-14 21:55
来自: 长沙
送出感谢: 4 次
接收感谢: 256 次

#2

帖子 eexpress » 2007-08-01 11:06

又见Zombie。。。我打仗的时候,经常看到自己的ping是这个哦。哎。

killall -9 scim-xxxxx
● 鸣学
头像
vcxzfdsarewq
帖子: 92
注册时间: 2007-04-20 18:22
来自: Matrix
送出感谢: 0
接收感谢: 0

#3

帖子 vcxzfdsarewq » 2007-08-01 11:28

eexpress 写了:又见Zombie。。。我打仗的时候,经常看到自己的ping是这个哦。哎。

killall -9 scim-xxxxx
杀不掉的,statnet的PPID是swiftfox,重启后还是有
scim的PPID是X-session-manager也是重启后有
用什么好的办法吗?
头像
eexpress
帖子: 58428
注册时间: 2005-08-14 21:55
来自: 长沙
送出感谢: 4 次
接收感谢: 256 次

#4

帖子 eexpress » 2007-08-01 12:27

不会吧。 -9都不行?????你sudo了????????
● 鸣学
头像
vcxzfdsarewq
帖子: 92
注册时间: 2007-04-20 18:22
来自: Matrix
送出感谢: 0
接收感谢: 0

#5

帖子 vcxzfdsarewq » 2007-08-01 12:42

eexpress 写了:不会吧。 -9都不行?????你sudo了????????
sudo 了,切换到superuser都不行

root@ubuntu:/etc# ps aux |grep "defunct"
hitch 5888 0.0 0.0 0 0 ? Z 11:25 0:00 [scim] <defunct>
root 6355 0.0 0.0 2884 752 pts/1 R+ 12:43 0:00 grep defunct
root@ubuntu:/etc# killall -9 scim
root@ubuntu:/etc# ps aux |grep "defunct"
hitch 5888 0.0 0.0 0 0 ? Z 11:25 0:00 [scim] <defunct>
root 6373 0.0 0.0 2884 752 pts/1 R+ 12:43 0:00 grep defunct
头像
nobrain
帖子: 808
注册时间: 2005-08-25 13:58
来自: ustc
送出感谢: 0
接收感谢: 0
联系:

#6

帖子 nobrain » 2007-08-01 13:06

看看这两个zombie进程的父进程是哪个
爱喝真猪奶茶的夜鸣猪
头像
vcxzfdsarewq
帖子: 92
注册时间: 2007-04-20 18:22
来自: Matrix
送出感谢: 0
接收感谢: 0

#7

帖子 vcxzfdsarewq » 2007-08-01 13:16

nobrain 写了:看看这两个zombie进程的父进程是哪个
是x-session-manag
我用killall -2 x-session-manag 重启后还是不行
头像
xhy
帖子: 3916
注册时间: 2005-12-28 1:16
系统: Ubuntu 12.10 X64
来自: 火星
送出感谢: 1 次
接收感谢: 0

#8

帖子 xhy » 2007-08-01 19:51

zomble进程是杀不掉的 唯一的办法就是重启

当子进程退出时 就会进入zomble状态 内核给子进程记录一些信息到一张表中
直到父进程调用wait系列系统调用去取回这些信息 子进程才能正常退出
目前负债150多万
头像
蓝蓝
帖子: 953
注册时间: 2007-06-09 9:19
来自: 上海
送出感谢: 0
接收感谢: 0
联系:

#9

帖子 蓝蓝 » 2007-08-01 19:59

顽症
太阳好毒…….
头像
nobrain
帖子: 808
注册时间: 2005-08-25 13:58
来自: ustc
送出感谢: 0
接收感谢: 0
联系:

#10

帖子 nobrain » 2007-08-01 20:15

xhy 写了:zomble进程是杀不掉的 唯一的办法就是重启

当子进程退出时 就会进入zomble状态 内核给子进程记录一些信息到一张表中
直到父进程调用wait系列系统调用去取回这些信息 子进程才能正常退出
或者把父进程咔嚓啦,由init进程wait
爱喝真猪奶茶的夜鸣猪
头像
xhy
帖子: 3916
注册时间: 2005-12-28 1:16
系统: Ubuntu 12.10 X64
来自: 火星
送出感谢: 1 次
接收感谢: 0

#11

帖子 xhy » 2007-08-01 21:11

nobrain 写了:
xhy 写了:zomble进程是杀不掉的 唯一的办法就是重启

当子进程退出时 就会进入zomble状态 内核给子进程记录一些信息到一张表中
直到父进程调用wait系列系统调用去取回这些信息 子进程才能正常退出
或者把父进程咔嚓啦,由init进程wait

一个进程退出时,内核会逐个检查系统中的活动进程,把所有这个进程的子进程的ppid改为1
而zomble中的进程不是活动进程 因此不会被init领养

一般遇到zomble可以无视 因此zomble仅仅占用一个进程描述符 以及少量的终止信息
对系统的影响忽略不计

如果在服务器中有大量的zomble出现 可能会导致达到进程上限 无法创建新的进程

个人使用的话 10000个zomble都无所谓的
目前负债150多万
头像
nobrain
帖子: 808
注册时间: 2005-08-25 13:58
来自: ustc
送出感谢: 0
接收感谢: 0
联系:

#12

帖子 nobrain » 2007-08-02 11:33

xhy 写了:一个进程退出时,内核会逐个检查系统中的活动进程,把所有这个进程的子进程的ppid改为1
而zomble中的进程不是活动进程 因此不会被init领养
在父进程退出的时候,zombie的子进程会被init领养的,写个程序就可以验证了。

代码: 全选

$ uname -r
2.6.20-16-generic

代码: 全选

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>

int main()
{
	switch(fork())
	{
		case -1:
			fprintf(stderr, "fork() failed\n");
			return EXIT_FAILURE;
			break;
		case 0: /* child process */
			printf("This is child pid = %ld\n",
					(long)getpid());
			switch(fork())
			{
				case -1:
					fprintf(stderr," fork failed\n");
					exit(EXIT_FAILURE);
					break;
				case 0:
					printf("grand process pid = %ld\n",
							(long)getpid());
					sleep(4);
					exit(EXIT_SUCCESS);
					break;
				default:
					break;
			}
			exit(EXIT_SUCCESS);
			break;
		default:
			break;
	}
	sleep(10);
	exit(EXIT_SUCCESS);
}
运行这个程序,并观察系统监视器。
父进程创建了子进程,子进程处于zombie状态。子进程的子进程即孙进程在sleep了4秒之后,先于父进程退出,但是这个孙进程并没有处于zombie状态,而是消失了。此时,子进程仍然存在并处于zombie状态。似乎zombie进程的子进程也被init领养了。
爱喝真猪奶茶的夜鸣猪
头像
skyx
论坛版主
帖子: 9203
注册时间: 2006-12-23 13:46
来自: Azores Islands
送出感谢: 0
接收感谢: 1 次
联系:

#13

帖子 skyx » 2007-08-02 12:26

比较相信楼上
no security measure is worth anything if an attacker has physical access to the machine
头像
xhy
帖子: 3916
注册时间: 2005-12-28 1:16
系统: Ubuntu 12.10 X64
来自: 火星
送出感谢: 1 次
接收感谢: 0

#14

帖子 xhy » 2007-08-02 13:36

linux 2.6的内核 + 近期版本的init 下实验过
父进程正常退出的情况下 确实可以回收大部分defunct进程
solaris9,AIX下情况不同

更正一下我上面的说法
严格的说回收僵尸进程不是内核的职责
这个工作是init做的 init定期检查并且回收
linux(2.6)下是这样的
unix下有所不同

两次fork可以避免僵尸进程 因此不能作为实验例子
我用的是其它测试程序
目前负债150多万
头像
BigSnake.NET
帖子: 12522
注册时间: 2006-07-02 11:16
来自: 廣州
送出感谢: 0
接收感谢: 7 次
联系:

#15

帖子 BigSnake.NET » 2007-08-02 13:38

父进程的缺陷,基本上可以无视
^_^ ~~~
要理解递归,首先要理解递归。

地球人都知道,理论上,理论跟实际是没有差别的,但实际上,理论跟实际的差别是相当大滴。
回复

回到 “老旧版本支持”