Linux中启动的后台Daemon因为没有tty与其相连,所以printf()或fprintf(stdout, .......)都没有地方可以显示。那么要在后台daemon中输出些message有什么方法呢?
可以使用syslog()函数,syslogd将会把message打印到/var/log/messages中 。方法很简单如下:
#include
void foo()
{
...........
openlog("foo", LOG_PID, LOG_USER);
syslog(LOG_INFO, "your-messages\n");
...........
}
运行foo后,打开/var/log/messages, 就可以看到 :
March 20 00:22:10 localhost foo[12312]: your-messages
其中方括号中的12312是后台daemon的pid(进程号)。
在centOS 6.x上,syslogd变成了rsyslog,如果一定时间内输出的log太多,rsyslogd就会丢弃一些log,在/var/log/messages里会看到这样的记录:
imuxsock begins to drop messages from pid 19341 due to rate-limiting
遇到这种情况,只要在/etc/rsyslog.conf中将限制条件改大一点即可,如下:
/etc/rsyslog.conf:
$ModLoad imuxsock # provides support for local system logging (e.g. via logger command)
# 增加下面两行
$SystemLogRateLimitInterv
al 2
#<- rsyslogd对log计数的时间单位为2秒
$SystemLogRateLimitBurst 500
#<- 计数时间单位里log数不超过500条
$ModLoad imklog
# provides kernel logging support (previously done by rklogd)
#$ModLoad immark
# provides --MARK-- message capability
可以使用syslog()函数,syslogd将会把message打印到/var/log/messages中 。方法很简单如下:
#include
void foo()
{
}
运行foo后,打开/var/log/messages, 就可以看到 :
其中方括号中的12312是后台daemon的pid(进程号)。
在centOS 6.x上,syslogd变成了rsyslog,如果一定时间内输出的log太多,rsyslogd就会丢弃一些log,在/var/log/messages里会看到这样的记录:
遇到这种情况,只要在/etc/rsyslog.conf中将限制条件改大一点即可,如下:
/etc/rsyslog.conf:
$ModLoad imuxsock # provides support for local system logging (e.g. via logger command)
# 增加下面两行
$SystemLogRateLimitInterv
$SystemLogRateLimitBurst 500
$ModLoad imklog
#$ModLoad immark
作了以上修改后,只要2秒内log数不超过500条rsyslogd就不会丢弃log了。