我在ubuntu 12.04上成功测试了以下syslog"hello world"示例:
// gcc giuspexample.c -o giuspexample
#include <syslog.h>
int main()
{
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;
}
Run Code Online (Sandbox Code Playgroud)
我可以读取/ var/log/syslog中的条目.关于如何更改目标文件路径,我按照http://www.codealias.info/technotes/syslog_simple_example上的说明进行操作
echo "local0.* /var/log/mylog" >> /etc/syslog.conf
Run Code Online (Sandbox Code Playgroud)
但试图跑
sudo /etc/init.d/syslog restart
Run Code Online (Sandbox Code Playgroud)
不起作用(命令未找到)并重新启动电脑无论如何都不会开始写/ var/log/mylog但仍然在/ var/log/syslog上.有人知道什么是错的吗?谢谢.
在/etc/rsyslog.d目录中,有两个文件:
20-ufw.conf50-default.conf我添加的文件/etc/rsyslog.d/30-mycustomname.conf有sudo nano,有以下内容:
# 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.
& ~
Run Code Online (Sandbox Code Playgroud)
然后我检查该文件/var/log/centro.log是否不存在
sudo rm -f /var/log/centro.log
Run Code Online (Sandbox Code Playgroud)
然后我重新启动服务
sudo service rsyslog restart
Run Code Online (Sandbox Code Playgroud)
最后以下代码有效:
// 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;
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
10874 次 |
| 最近记录: |