根本的な原因を見つけたと思いますが、Python2.7 のバグである可能性があります。キャッチ可能なすべてのシグナルをキャッチして無視した後、さらにエラー メッセージを追跡し、socket.error のヒントを得ることができました。問題は、そのようなエラーは最初に SIGTERM をトリガーし (実際にプロセスを強制終了しようとします)、次に STDERR に書き込みます。すべての STDOUT および STDERR をキャッチする私のメカニズムは、メイン プロセスが強制終了されたため、メッセージをログに記録できます。とにかく、これはデーモンの問題です。これらは、プロセスが終了する直前のログの最後の行です
2013-05-07 11:05:53,194 - STDERR - ERROR - Traceback (most recent call last):
2013-05-07 11:05:53,304 - STDERR - ERROR - File "/var/lib/netcam_epd/lib/python2.7/SocketServer.py", line 582, in process_request_thread
2013-05-07 11:05:53,415 - STDERR - ERROR - self.finish_request(request, client_address)
2013-05-07 11:05:53,489 - STDERR - ERROR - File "/var/lib/netcam_epd/lib/python2.7/SocketServer.py", line 323, in finish_request
2013-05-07 11:05:53,587 - STDERR - ERROR - self.RequestHandlerClass(request, client_address, self)
2013-05-07 11:05:53,684 - STDERR - ERROR - File "/var/lib/netcam_epd/lib/python2.7/SocketServer.py", line 640, in __init__
2013-05-07 11:05:53,835 - STDERR - ERROR - self.finish()
2013-05-07 11:05:53,887 - STDERR - ERROR - File "/var/lib/netcam_epd/lib/python2.7/SocketServer.py", line 693, in finish
2013-05-07 11:05:54,084 - STDERR - ERROR - self.wfile.flush()
2013-05-07 11:05:54,182 - STDERR - ERROR - File "/var/lib/netcam_epd/lib/python2.7/socket.py", line 303, in flush
2013-05-07 11:05:54,326 - STDERR - ERROR - self._sock.sendall(view[write_offset:write_offset+buffer_size])
2013-05-07 11:05:54,387 - STDERR - ERROR - error: [Errno 32] Broken pipe
どうやら、これは書き込み不可能なソケットに書き込もうとしたことが原因でした。ソケットは通常の実行でいつでも閉じることができるため、エラー/例外をスローするだけでなく、ライブラリは適切な戻り値でこれをより適切に処理する必要があると思います。
これが実際に根本原因であるかどうかを確認します。