我在我的代碼中使用python守護進程中有打印語句。我想將它們發送到一個文件,所以我跑了以下內容:python守護進程不記錄標準輸出重定向
python server.py >> log.out
然而,沒有進去log.out
。
任何人都可以告訴我我需要做什麼嗎?
謝謝。
我在我的代碼中使用python守護進程中有打印語句。我想將它們發送到一個文件,所以我跑了以下內容:python守護進程不記錄標準輸出重定向
python server.py >> log.out
然而,沒有進去log.out
。
任何人都可以告訴我我需要做什麼嗎?
謝謝。
如果它已經作爲守護進程運行,那麼您很可能需要強制重定向STDOUT,STDERR等。您可以在I/O Redirection here上閱讀更多內容。
python server.py 2>log.out >&2
如果在代碼中有錯誤,它將不會寫入文件。見http://tldp.org/HOWTO/Bash-Prog-Intro-HOWTO-3.html
嘗試創建這個文件:
print 'stdout'
raise Exception('stderr')
的DaemonContext對象允許重定向標準輸出/標準錯誤/標準輸入,當你創建對象。例如:
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。
你能告訴我們一些示例代碼嗎? –