mirror of
https://github.com/xcat2/confluent.git
synced 2025-01-23 08:04:09 +00:00
Add facility to dump trace to log
If confluent gets stuck, provide a debug facility to sample where it is stuck. Sending confluent SIGUSR1 will now cause /var/log/confluent/hangtraces to get written to.
This commit is contained in:
parent
5485ef36bf
commit
f02c74cce0
@ -50,6 +50,8 @@ except ImportError:
|
||||
import sys
|
||||
import os
|
||||
import signal
|
||||
import time
|
||||
import traceback
|
||||
|
||||
|
||||
def _daemonize():
|
||||
@ -119,6 +121,11 @@ def _checkpidfile():
|
||||
def terminate(signalname, frame):
|
||||
sys.exit(0)
|
||||
|
||||
def dumptrace(signalname, frame):
|
||||
ht = open('/var/log/confluent/hangtraces', 'a')
|
||||
ht.write('Dumping active trace on ' + time.strftime('%X %x\n'))
|
||||
ht.write(''.join(traceback.format_stack(frame)))
|
||||
ht.close()
|
||||
|
||||
def doexit():
|
||||
if not havefcntl:
|
||||
@ -138,6 +145,7 @@ def _initsecurity(config):
|
||||
|
||||
|
||||
def run():
|
||||
signal.signal(signal.SIGUSR1, dumptrace)
|
||||
if havefcntl:
|
||||
_checkpidfile()
|
||||
conf.init_config()
|
||||
|
Loading…
x
Reference in New Issue
Block a user