我在 ubuntu 12.04 上成功测试了以下系统日志“hello world”示例:
// gcc giuspexample.c -o giuspexample
#include <syslog.h>
int main(int argc, char *argv[])
{
setlogmask(LOG_UPTO (LOG_NOTICE));
openlog("atm", LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL0);
syslog(LOG_NOTICE, "Program started by User %d", getuid ());
syslog(LOG_INFO, "A tree falls in a forest");
closelog();
return 0;
}
我可以读取 /var/log/syslog 中的条目。我按照以下说明进行操作http://www.codealias.info/technotes/syslog_simple_example关于如何更改目标文件路径
echo "local0.* /var/log/mylog" >> /etc/syslog.conf
但试图跑
sudo /etc/init.d/syslog restart
不起作用(未找到命令)并且重新启动电脑无论如何都不会开始在 /var/log/mylog 上写入,但仍在 /var/log/syslog 上。有人知道出了什么问题吗?谢谢。
答案1
这就是我成功的方法。
在我的文件夹 /etc/rsyslog.d 中有两个文件:
20-ufw.conf 和 50-default.conf
我添加了一个文件:
sudo nano /etc/rsyslog.d/30-mycustomname.conf
内容如下:
# Log QSD Centro generated log messages to file
if $programname == 'centro' then /var/log/centro.log
# Uncomment the following to stop logging anything that matches the last rule.
& ~
然后我检查文件 /var/log/centro.log 不存在
sudo rm -f /var/log/centro.log
然后我重新启动服务
sudo service rsyslog restart
最后以下代码有效:
// gcc centro.c -o centro
#include <stdio.h>
#include <syslog.h>
int main(int argc, char *argv[])
{
openlog(NULL, 0, LOG_USER);
syslog(LOG_INFO, "MORTACCI TUA!!!");
closelog();
return 0;
}
答案2
默认情况下 Ubuntu 使用 rsyslog。它的配置文件位于
/etc/rsyslog.conf
和
/etc/rsyslog.conf