python-daemon 不记录标准输出重定向

问题描述 投票:0回答:4

我在我的代码中使用 python-daemon,其中有打印语句。我想将它们发送到一个文件中,所以我运行了以下命令:

python server.py >> log.out

然而,什么也没有进去

log.out
.

谁能告诉我我需要做什么?

谢谢。

python stdout daemon
4个回答
5
投票

DaemonContext 对象允许在创建对象时重定向 stdout/stderr/stdin。例如:

import os
import daemon


if __name__ == '__main__':
    here = os.path.dirname(os.path.abspath(__file__))
    out = open('checking_print.log', 'w+')

    with daemon.DaemonContext(working_directory=here, stdout=out):
        for i in range(1, 1000):
            print('Counting ... %s' % i)

您应该能够

cat checking_print.log
并查看打印语句的输出。

DaemonContext 对象的一个很好的参考是PEP 3143


0
投票

“问题”是 python-daemon 关闭了all 文件描述符,包括标准输出。您要么需要执行@elarson 建议的操作,要么(如果您想在启动守护程序时保持 stdout 重定向)通过添加类似

的内容来排除 sys.stdout 被关闭
files_preserve = [sys.stdout]

给你 DaemonContext 调用。


-1
投票

如果你的代码有错误,它不会被写入文件。请参见http://tldp.org/HOWTO/Bash-Prog-Intro-HOWTO-3.html

尝试创建这个文件:

print 'stdout'
raise Exception('stderr')

-2
投票

如果它已经作为守护进程运行,您很可能需要强制重定向 STDOUT、STDERR 等。您可以在此处阅读有关I/O 重定向的更多信息

python server.py 2>log.out >&2
© www.soinside.com 2019 - 2024. All rights reserved.