2
0
mirror of https://github.com/xcat2/confluent.git synced 2025-10-23 23:45:40 +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:
Jarrod Johnson
2015-10-28 10:16:39 -04:00
parent 5485ef36bf
commit f02c74cce0

View File

@@ -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()