Linux后台Daemon中打印debug message的方法

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

作了以上修改后,只要2秒内log数不超过500条rsyslogd就不会丢弃log了。


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值