我在我的代码中使用 python-daemon,其中包含打印语句。我想将它们发送到一个文件,所以我运行了以下命令:
python server.py >> log.out
然而,什么都没有进去log.out
。
谁能告诉我我需要做什么?
谢谢。
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。
如果您的代码中有错误,则不会将其写入文件。请参阅http://tldp.org/HOWTO/Bash-Prog-Intro-HOWTO-3.html
尝试创建此文件:
print 'stdout'
raise Exception('stderr')
如果它已经作为守护进程运行,您很可能需要强制重定向 STDOUT、STDERR 等。您可以在此处阅读有关 I/O 重定向的更多信息。
python server.py 2>log.out >&2