linux-守护进程daemon

linux-守护进程daemon

代码实现 main.c


//pName:程序名
//facility: 守护进程,输出日志类型 302页
#include<signal.h>
#include<syslog.h>
#include<fcntl.h>
static int daemon_proc = 0;
#define MAXDF 64
int test_daemon(const char* pName, int facility)
{
	int i;
	pid_t pid;

	if((pid = fork()) < 0)
	{
		return -1;
	}
	else if(pid) //主进程退出
	{
		_exit(0);
	}

	//创建新会话
	if((setsid() < 0))
	{
		return;
	}

	//屏蔽终端挂断的消息
	signal(SIGHUP,SIG_IGN);

	//子进程再fork一次
	//防止子进程变成新会话的守进程,当没终端的会话打开终端时,终端最后会变成会话守进程的终端
	//为了确保守护进程将来打开终端时也不会获得终端
	if((pid = fork()) < 0)
	{
		return -1;
	}
	else if(pid) 
	{
		_exit(0);
	}

	//标识当前程序是否是守护进程
	daemon_proc = 1;

	//修改工作目录到根目录
	chdir("/"); 

	//关闭文件描述符号
	for(int i=0; i<MAXDF; ++i)
	{
		close(i);
	}
	//指定 stdin stdout strerror的日志输出目录
	//每个文件都属于自己的句柄,例如标准输入是0,标准输出是1,标准出错是2
	//打开0 1 2 防止 创建socket时被占用
    int p1 = open("/dev/NULL",O_RDONLY);
	int p2 = open("/dev/NULL",O_RDWR);
	int p3 = open("/dev/NULL",O_RDWR);

	//输出的日志内容在:/var/log/message 中
	openlog(pName,LOG_PID,facility); 
	syslog(LOG_DEBUG, "daemon create\r\n");
	return 0;
}

int main(int argc, char **argv)
{
	test_daemon("test_daemon",0);
	while(1)
	{
		syslog(LOG_DEBUG, "daemon test\r\n");
	}
	return 0;
}


运行结果

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值