implement graceful shutdown in sslocal; close #179

This commit is contained in:
clowwindy 2014-09-12 20:47:04 +08:00
parent a6b8a5eef9
commit fdb3a36170
2 changed files with 8 additions and 1 deletions

View file

@ -24,6 +24,7 @@
import sys
import os
import logging
import signal
import utils
import encrypt
import eventloop
@ -58,6 +59,12 @@ def main():
dns_resolver.add_to_loop(loop)
tcp_server.add_to_loop(loop)
udp_server.add_to_loop(loop)
def handler(signum, _):
logging.warn('received SIGQUIT, doing graceful shutting down..')
tcp_server.close(next_tick=True)
udp_server.close(next_tick=True)
signal.signal(signal.SIGQUIT, handler)
loop.run()
except (KeyboardInterrupt, IOError, OSError) as e:
logging.error(e)

View file

@ -24,13 +24,13 @@
import sys
import os
import logging
import signal
import utils
import encrypt
import eventloop
import tcprelay
import udprelay
import asyncdns
import signal
def main():