syslog_dema.c

来自「linux多线程编程的例程」· C语言 代码 · 共 50 行

C
50
字号
/*syslog_dema.c利用syslog服务的守护进程实例*/
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<fcntl.h>
#include<sys/types.h>
#include<unistd.h>
#include<sys/wait.h>
#include<syslog.h>
         
#define MAXFILE 65535
int main()
{
	pid_t pc,sid;
	int i,fd,len;
	char *buf="This is a Dameon\n";
	len =strlen(buf);
	pc=fork();
	if(pc<0){
		printf("error fork\n");
		exit(1);
	}else if(pc>0)
	exit(0);
/*打开系统日志服务,openlog*/
	openlog("demo_update",LOG_PID, LOG_DAEMON);
	if((sid=setsid())<0){
		syslog(LOG_ERR, "%s\n", "setsid");
		exit(1);
	}
	if((sid=chdir("/"))<0){
		syslog(LOG_ERR, "%s\n", "chdir");
		exit(1);
	}
	umask(0);
	for(i=0;i<MAXFILE;i++)
		close(i);
	while(1){
/*打开守护进程的日志文件,并写入open的日志记录*/
		if((fd=open("/tmp/dameon.log",O_CREAT|O_WRONLY|O_APPEND, 0600))<0){
			syslog(LOG_ERR, "open");
			exit(1);
			}
		write(fd, buf, len+1);
		close(fd);
		sleep(10);
	}
	closelog();
	exit(0);
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?