Linux下能实现的守护进程代码为何在Unix系统下无法实现?
本帖最后由 冷寒生 于 2011-05-08 09:24 编辑
- //////////////////////////////init_daemon.c 开始///////////////////////////////////////////
- #include <unistd.h>
- #include <signal.h>
- #include <sys/param.h>
- #include <sys/types.h>
- #include <sys/stat.h>
- /*********************************************************************
- *filename: init_daemon.c
- *purpose: 产生后台进程
- *wrote by: zhoulifa([email]zhoulifa@163.com[/email]) 周立发([url]http://zhoulifa.bokee.com[/url])
- *date time:2006-03-10 01:00:00
- *Thanks to: 北京工业大学 小胡(本文摘自[url]http://www.qtcn.org/bbs/simple/index.php?t116.html[/url])
- *Note: 任何人可以任意复制代码并运用这些代码,当然包括你的商业用途
- * 但请遵循GPL
- *********************************************************************/
- void init_daemon(void)
- {
- int pid;
- int i;
- if(pid=fork())
- exit(0);//是父进程,结束父进程
- else if(pid< 0)
- exit(1);//fork失败,退出
- //是第一子进程,后台继续执行
- setsid();//第一子进程成为新的会话组长和进程组长
- //并与控制终端分离
- if(pid=fork())
- exit(0);//是第一子进程,结束第一子进程
- else if(pid< 0)
- exit(1);//fork失败,退出
- //是第二子进程,继续
- //第二子进程不再是会话组长
- for(i=0;i< NOFILE;++i)//关闭打开的文件描述符
- close(i);
- chdir("/tmp");//改变工作目录到/tmp
- umask(0);//重设文件创建掩模
- return;
- }
- //////////////////////////////init_daemon.c 结束///////////////////////////////////////////
- 上面这是个通用的函数,可以让你的程序成为后台守护进程。
- 下面是一个测试程序:
- //////////////////////////////daemontest.c 开始///////////////////////////////////////////
- #include <stdio.h>
- #include <time.h>
- /*********************************************************************
- *filename: daemontest.c
- *purpose: 测试后台进程
- *wrote by: zhoulifa([email]zhoulifa@163.com[/email]) 周立发([url]http://zhoulifa.bokee.com[/url])
- *date time:2006-03-10 01:09:00
- *Thanks to: 北京工业大学 小胡(本文参考了其文章[url]http://www.qtcn.org/bbs/simple/index.php?t116.html[/url])
- *Note: 任何人可以任意复制代码并运用这些代码,当然包括你的商业用途
- * 但请遵循GPL
- *********************************************************************/
- void init_daemon(void);//守护进程初始化函数
- void signal_reload(int signal)
- {
- /*当收到SIGUSR1信号时程序重新导入所有参数*/
- FILE *fp;
- time_t t;
- if((fp=fopen("test.log","a")) >=0)
- {
- t=time(0);
- fprintf(fp,"I received signal(%d), reload all parameters at %s\n", signal, asctime(localtime(&t)) );
- fclose(fp);
- }
- /*重新导入参数*/
- }
- void signal_handle(int signal)
- {
- /*当收到SIGUSR2信号时程序退出*/
- FILE *fp;
- time_t t;
- if((fp=fopen("test.log","a")) >=0)
- {
- t=time(0);
- fprintf(fp,"I received signal(%d), exit at %s\n", signal, asctime(localtime(&t)) );
- fclose(fp);
- }
- exit(0);
- }
- int main(int argc, char ** argv)
- {
- FILE *fp;
- time_t t;
- init_daemon();//初始化为Daemon
- signal(SIGCHLD, SIG_IGN);/*忽略子进程退出信号,若在此之后又产生了子进程,
- 如果不处理此信号,将在子进程退出后产生僵尸进程*/
- signal(SIGUSR1, signal_reload);/*处理SIGUSR1信号,可以定义此信号为重导参数信号*/
- signal(SIGUSR2, signal_handle);/*处理SIGUSR2信号,可以定义此信号为退出信号*/
- while(1)//每隔一分钟向test.log报告运行状态
- {
- /*这是各位程序的主体部分,所以的工作在下面完成,比如http服务、FTP服务等*/
- sleep(60);//睡眠一分钟
- if((fp=fopen("test.log","a")) >=0)/*注意,由于在init_daemon里面已经把路径切换到了/tmp,因此此文件是/tmp/test.log*/
- {
- t=time(0);
- fprintf(fp,"I'm here at %s\n",asctime(localtime(&t)) );
- fclose(fp);
- }
- }
- }
复制代码以上代码引自 http://blog.chinaunix.net/space. ... =blog&id=296431
以上代码在Linux系统下可以成功执行,通过ps -ef可以看到运行的进程
但我在FreeBSD下却始终无法实现,请问题Linux环境编程和Unix环境编程是有一定区别的么?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
人品爆发了,以上这段代码我一直以为是Unix和Linux的实现方法不一样,结果是用错了ps命令。
在Linux下用ps -ef就可以查看守护进程,但在Unix下却是用ps –axj
最终测试结果:以上代码在Linux/Unix均能调试通过。