使用systemd启动的进程正在记录到/ var/log/syslog和/var/log/daemon.log

Dav*_*ave 7 linux logging systemd

我在Beaglebone Black上运行了几个python脚本,两者都是在initd上由systemd启动的.昨天我注意到我的eMMC闪存完全已满,原因是我有1.8 GB的日志文件.似乎这些脚本的标准输出(它们为调试目的生成大量数据)被记录到/ var/log/syslog和/var/log/daemon.log中.此外,/ var/log/messages有大量关于"速率限制"的条目.

现在,我假设我可以通过在这些脚本上禁用标准输出来解决这个问题.但是,我宁愿保留该功能,并以某种方式告诉systemd不要记录该数据.但是,我一直无法找到相关信息.

以下是我当前.service文件的示例:

[Unit]
Description=Description of my process
After=network.target
[Service]
Type=simple
ExecStart=/opt/myprocess
[Install]
WantedBy=multi-user.target
Run Code Online (Sandbox Code Playgroud)

我应该注意到我最初将syslog.target作为"After"目标,只是因为我跟随的例子有它.但我已经删除它,它似乎没有解决问题.

任何有关此问题的帮助或见解将不胜感激.

编辑:我可能在这里找到答案:

http://www.kibinlabs.com/systemd-logging-tricks/

添加StandardOutput = null并查看是否修复了它.看起来很有希

编辑2:确实如此.

lar*_*sks 5

/var/logSystemD永远不会自行记录文件。

如果日志消息显示在 中/var/log,这表明您的系统正在运行“syslog”守护进程,该守护进程正在 (a) 通过读取 systemd 日志,或 (b) 通过直接使用 syslog 的应用程序接收日志消息。

只需禁用您的 syslog 守护进程就会阻止文件写入/var/log. 消息仍将写入系统日志,但您可以使用相当灵活的控件来限制这些文件使用的空间。有关更多信息,请参阅日志文档。