Chinaunix首页 | 论坛 | 博客
  • 博客访问: 299417
  • 博文数量: 103
  • 博客积分: 2345
  • 博客等级: 大尉
  • 技术积分: 902
  • 用 户 组: 普通用户
  • 注册时间: 2009-09-01 09:10
文章分类

全部博文(103)

文章存档

2022年(1)

2018年(3)

2017年(2)

2016年(3)

2015年(8)

2014年(8)

2013年(2)

2012年(9)

2011年(29)

2010年(20)

2009年(18)

我的朋友

分类:

2010-08-19 10:35:23

1、调用函数fork()创建子进程,然后父进程终止,保留子进程继续运行。之所以要让父进程终止是因为,当一个进程是以前台进程方式由shell启动时,在父进程终止之后子进程自动转为后台进程。另外,我们在下一步要创建一个新的会晤期,这就要求创建会晤期的进程不是一个进程组的组长进程。当父进程终止,子进程运行,这就保证了进程组的组ID与子进程的进程ID不会相等。

或者

使用 setsid 设置为新会话的领头进程,因为 setsid 要求调用进程不是会话的领头进程时才有效.因此, 首先可用 fork 派生, 并结束父进程.之后调用 setsid, 子进程成为新会话的领头进程, 从而与原有会话, 进程组, tty 脱离.但是, 为避免作为新会话领头进程的子进程在打开一个终端设备时, 拥有一个控制终端.再次派生, 并结束父进程, 可让子进程成为非会话领头进程.
    if (fork ())
        exit (0);
   
    setsid ();

    if (fork ())
        exit (0);

2、信号处理,包括处理 SIGCHLD 信号, 为避免形成僵尸进程。

3、关闭不再需要的文件描述符,并为标准输入、标准输出和标准错误输出打开新的文件描述符(也可以继承父进程的标准输入、标准输出和标准错误输出文件描述符,这个操作是可选的)。
例如:
for (i=0; i < NOFILE; i++) close (i);

4、调用函数chdir("/")将当前工作目录更改为根目录。这是为了保证我们的进程不使用任何目录。否则我们的守护进程将一直占用某个目录,这可能会造成超级用户不能卸载一个文件系统。

5、调用函数umask(0)将文件方式创建屏蔽字设置为"0"。这是因为由继承得来的文件创建方式屏蔽字可能会禁止某些许可权。例如我们的守护进程需要创建一组可读可写的文件,而此守护进程从父进程那里继承来的文件创建方式屏蔽字却有可能屏蔽掉了这两种许可权,则新创建的一组文件其读或写操作就不能生效。因此要将文件方式创建屏蔽字设置为"0"。

阅读(676) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~