我已经设置了 syslog-ng 来跟踪文件并将每个新事件转发到将处理它的 python 脚本。
我的 syslog-ng.conf 看起来像这样 -
source s_src {
file("/var/log/xyz.log" flags(no_parse);
};
destination d_dest {
program("python -u /home/user1/processlog.py" flush_lines(1) flags(no_multi_line));
};
log { source(s_src); destination(d_dest); };
而 processlog.py 只包含
#!/usr/bin/python
import sys
f1 = open('success.txt', 'a')
while 0 < 1:
try:
line = sys.stdin.readline()
f1.write(line)
except Exception, e:
f = open('/tmp/error.txt','ab')
f.write(e)
f.close()
exit(0)
该脚本在命令行中运行良好。接受每个输入并写入success.txt。
Syslog-ng 也会启动,但不会将事件转发到上面的 python 程序。它虽然启动了程序。
ps -ef| grep processlog
root 6242 6236 0 13:00 ? 00:00:00 /bin/sh -c python -u /home/user1/processlog.py
root 6244 6242 0 13:00 ? 00:00:00 python -u /home/user1/processlog.py
我也检查了所有权限。但是,每当 xyz.log 中发生新事件时,它都不会被转发到 python 脚本,我正在通过写入 success.txt 进行测试
任何线索都受到高度赞赏。