免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2077 | 回复: 7
打印 上一主题 下一主题

[C] 关于APUE的守护进程实例 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-01-12 10:26 |只看该作者 |倒序浏览
APUE2 [13.3]
按书上的例子,简单的写了个daemon.c  编译成功,但是执行程序时,程序却退出了,查看日志unexpected file descriptors 0 1 2.
请问这是什么原因啊?

  1. [root@mylinux ap]# vi 13.3daemon.c   
  2.       1 #include    <unistd.h>
  3.       2
  4.       3 int
  5.       4 main(void)
  6.       5 {
  7.       6     daemonize("mydaemon");
  8.       7     pause();
  9.       8
  10.       9     exit(0);
  11.      10 }
  12. [root@mylinux ap]# gcc -c 13.3daemon.c
  13. [root@mylinux ap]# gcc 13.3daemon.o 13.3daemonize.o
  14. [root@mylinux ap]# ./a.out
  15. [root@mylinux ap]# vi /var/log/messages
  16. 829 Jan 11 21:44:14 mylinux mydaemon: unexpected file descriptors 0 1 2
  17. [root@mylinux ap]# uname -a
  18. Linux mylinux.xiaodao.com 2.6.9-34.EL #1 Fri Feb 24 16:44:51 EST 2006 i686 i686 i386 GNU/Linux
复制代码

论坛徽章:
0
2 [报告]
发表于 2008-01-12 10:52 |只看该作者
直接调daemon函数,更简单

论坛徽章:
0
3 [报告]
发表于 2008-01-12 11:07 |只看该作者

回复 #2 cugb_cat 的帖子

谢谢提醒。。

不过,我还是想知道上面的那个程序是哪儿错了

论坛徽章:
0
4 [报告]
发表于 2008-01-12 11:16 |只看该作者
daemonize("mydaemon");
的代码呢?

论坛徽章:
0
5 [报告]
发表于 2008-01-12 11:22 |只看该作者
原帖由 flw2 于 2008-1-12 11:16 发表
daemonize("mydaemon");
的代码呢?

daemonize这个函数是APUE2 [13.3] 上的范例程序

  1. #include "apue.h"
  2. #include <syslog.h>
  3. #include <fcntl.h>
  4. #include <sys/resource.h>

  5. void
  6. daemonize(const char *cmd)
  7. {
  8.     int                 i, fd0, fd1, fd2;
  9.     pid_t               pid;
  10.     struct rlimit       rl;
  11.     struct sigaction    sa;
  12.     /*
  13.      * Clear file creation mask.
  14.      */
  15.     umask(0);

  16.     /*
  17.      * Get maximum number of file descriptors.
  18.      */
  19.     if (getrlimit(RLIMIT_NOFILE, &rl) < 0)
  20.         err_quit("%s: can't get file limit", cmd);

  21.     /*
  22.      * Become a session leader to lose controlling TTY.
  23.      */
  24.     if ((pid = fork()) < 0)
  25.         err_quit("%s: can't fork", cmd);
  26.     else if (pid != 0) /* parent */
  27.         exit(0);
  28.     setsid();

  29.     /*
  30.      * Ensure future opens won't allocate controlling TTYs.
  31.      */
  32.     sa.sa_handler = SIG_IGN;
  33.     sigemptyset(&sa.sa_mask);
  34.     sa.sa_flags = 0;
  35.     if (sigaction(SIGHUP, &sa, NULL) < 0)
  36.         err_quit("%s: can't ignore SIGHUP");
  37.     if ((pid = fork()) < 0)
  38.         err_quit("%s: can't fork", cmd);
  39.     else if (pid != 0) /* parent */
  40.         exit(0);

  41.     /*
  42.      * Change the current working directory to the root so
  43.      * we won't prevent file systems from being unmounted.
  44.      */
  45.     if (chdir("/") < 0)
  46.         err_quit("%s: can't change directory to /");

  47.     /*
  48.      * Close all open file descriptors.
  49.      */
  50.     if (rl.rlim_max == RLIM_INFINITY)
  51.         rl.rlim_max = 1024;
  52.     for (i = 0; i < rl.rlim_max; i++)
  53.         close(i);

  54.     /*
  55.      * Attach file descriptors 0, 1, and 2 to /dev/null.
  56.      */
  57.     fd0 = open("/dev/null", O_RDWR);
  58.     fd1 = dup(0);
  59.     fd2 = dup(0);

  60.     /*
  61.      * Initialize the log file.
  62.      */
  63.     openlog(cmd, LOG_CONS, LOG_DAEMON);
  64.     if (fd0 != 0 || fd1 != 1 || fd2 != 2) {
  65.         syslog(LOG_ERR, "unexpected file descriptors %d %d %d",
  66.           fd0, fd1, fd2);
  67.         exit(1);
  68.     }
  69. }
复制代码

论坛徽章:
0
6 [报告]
发表于 2008-01-12 11:36 |只看该作者
if 都为假了,你打印确是012,自己调吧

论坛徽章:
0
7 [报告]
发表于 2008-01-12 11:58 |只看该作者
狂晕啊。。
刚刚发现我的13.3daemonize.c写错了。。。。。
13.3daemonize.c我并没有直接复制,而是看了一遍范例后,合上书自己写的。
嘎嘎居然把if (fd0 != 0 || fd1 != 1 || fd2 != 2)写成了if (fd0 != 0 || fd1 != 0 || fd2 != 0)

弱弱地问一下,哪里有墙,我面壁思过去。。。。。。。。。

论坛徽章:
1
2017金鸡报晓
日期:2017-01-10 15:19:56
8 [报告]
发表于 2008-01-15 12:13 |只看该作者
你去撞吧
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP