print ステートメントを含むコードで 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
print ステートメントからの出力を確認できるはずです。
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