我正在使用第三方 .NET Core 应用程序(VS Code 扩展使用的二进制发行版),不幸的是,该应用程序启用了诊断日志记录,但没有明显的方法来禁用它(我已经向作者报告了这一点)。理想的解决方案(除了能够禁用它之外)是,如果我可以指定 systemd 它不应该为该特定程序记录任何内容,但我一直无法找到任何方法来执行此操作。这是迄今为止我尝试过的所有内容:
我尝试的第一件事是重定向stdout
并stderr
到/dev/null
: dotnet-app > /dev/null 2>&1
。这确实禁用了任何正常输出,但诊断日志记录仍在写入 systemd 日志。
我希望应用程序有一个命令行参数,允许我禁用诊断日志记录。它确实有一个冗长的参数,但经过实验,它似乎只对正常输出有影响,对诊断日志记录没有影响。
通过使用strace
并查找对 的调用connect
,我发现应用程序将诊断日志直接写入到/dev/log
.
该路径/dev/log
是 的符号链接/run/systemd/journal/dev-log
,因此为了验证我的发现,我将符号链接更改为指向/dev/null
。这确实阻止了诊断日志记录出现在 systemd 日志中。
有人告诉我LD_PRELOAD
并制作了一个库,connect
用我自己的版本替换了标准,在尝试连接到/dev/log
. 这在我的测试程序中工作正常,但在 .NET Core 应用程序中失败,在connect ENOENT /tmp/CoreFxPipe_1ddf2df2725f40a68990c92cb4d1ff1e
. 我尝试了我的库,但即使我所做的只是直接将参数传递给标准connect
函数,它仍然会失败并出现相同的错误。
然后,我尝试使用 Linux 命名空间来实现它,以便仅/dev/log
指向/dev/null
.NET Core 应用程序:unshare --map-root-user --mount sh -c "mount --bind /dev/null /dev/log; dotnet-app $@"
. …