Chinaunix首页 | 论坛 | 博客
  • 博客访问: 713492
  • 博文数量: 240
  • 博客积分: 3616
  • 博客等级: 大校
  • 技术积分: 2663
  • 用 户 组: 普通用户
  • 注册时间: 2010-04-21 23:59
文章分类

全部博文(240)

文章存档

2013年(6)

2012年(80)

2011年(119)

2010年(35)

分类: LINUX

2010-10-25 16:27:04

#include
#include
#include
#include
#include
#include
#include
#include
#define MAXFILE 65536
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("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 {
  close(i); 
 }
 while(1)
 {
  if((fd=open("/tmp/dameon.log",O_CREAT|O_WRONLY |O_APPEND,0600))<0)
  {
   syslog(LOG_ERR,"open");//打开守护进程的日志文件,并写入open的日志记录
   exit(1); 
  } 
  write(fd,buf,len+1);
  close(fd);
  sleep(10);
  
 }
 closelog();
 exit(0);
 
}
/*-------------------------------------------
1.守护进程的出错处理
使用syslog服务,将程序中的出错信息输入到"/var/log/message"系统日志中,从而可以直观
地看到程序的问题所在.
syslog是linux中的系统日志管理服务,通过守护进程syslogd来维护。该守护进程在启动时会
读一个培植文件"/etc/syslog.conf".该文件决定了不同种类的消息会发送向何处。
该机制提供了3个syslog函数,分别为openlog,syslog和closelog.
2.opnelog函数语法
1)所需要的头文件
#include
2)函数原型
void openlog(char *ident,int option,int facility)
3)输入参数
ident:要向每个消息加入字符串,通常为程序的名称
option:
LOG_CONS:如果消息无法送到系统日志服务,则直接输出到系统控制终端
LOG_NDELAY:立即打开系统日志服务的连接,在正常情况下,直到发送到第一条消息时才
打开连接
LOG_PERROR:将消息也同时送到stderr
LOG_PID:在每条消息中包含进程的PID
facility:
LOG_AUTHPRIV:安全/授权讯息
LOG_CRON:时间守护进程(cron及at)
LOG_DAEMON:其他系统守护进程
LOG_KERN:内核信息
LOG_LOCAL[0-7]:保留
LOG_LPR:行打印机子系统
LOG_MAIL:邮件子系统
LOG_NEWS:新闻子系统
LOG_SYSLOG:syslogd内部所产生的信息
LOG_USER:一般使用者等级讯息
LOG_UUCP:UUCP子系统
3.syslog函数语法
1)所需头文件:#include
2)函数原型:void syslog(int priority,char *format,...)
3)函数输入参数
priority
LOG_EMERG:系统无法使用
LOG_ALERT:需要立即采取措施
LOG_CRIT:有错误发生
LOG_WARNING:有警告发生
LOG_NOTICE:正常情况,但也是重要情况
LOG_INFO:信息消息
LOG_DEBUG:调试信息
format:以字符串指针的形式表示输出的格式,类似printf中的格式
4.closelog
1)所需头文件 #include
2)函数原型:void closelog(void)

----------------------------------------------*/
实验
1.
[root@localhost the_seventh_step]# gcc syslog_dema.c -o syslog_dema
2.
[root@localhost the_seventh_step]# tail -f /tmp/dameon.log
this is a Dameon
this is a Dameon
this is a Dameon
this is a Dameon
this is a Dameon
this is a Dameon
this is a Dameon
this is a Dameon
this is a Dameon
3.
[root@localhost the_seventh_step]# ps -ef |grep dameon
root      5954  3363  0 16:25 pts/1    00:00:00 grep dameon
4.
cat /var/log/message
阅读(957) | 评论(1) | 转发(0) |
给主人留下些什么吧!~~

chinaunix网友2010-10-26 18:58:08

很好的, 收藏了 推荐一个博客,提供很多免费软件编程电子书下载: http://free-ebooks.appspot.com