python: Try to shut ashd-wsgi down more nicely upon signal receipt.
authorFredrik Tolf <fredrik@dolda2000.com>
Mon, 3 Aug 2015 01:51:20 +0000 (03:51 +0200)
committerFredrik Tolf <fredrik@dolda2000.com>
Mon, 3 Aug 2015 01:51:20 +0000 (03:51 +0200)
python/ashd-wsgi
python3/ashd-wsgi3

index b671059..d5438fa 100755 (executable)
@@ -1,6 +1,6 @@
 #!/usr/bin/python
 
-import sys, os, getopt, socket, logging, time
+import sys, os, getopt, socket, logging, time, signal
 import ashd.util, ashd.serve
 try:
     import pdm.srv
@@ -191,6 +191,11 @@ except ValueError as exc:
     sys.stderr.write("ashd-wsgi: %s\n" % exc)
     sys.exit(1)
 
+def sigterm(sig, frame):
+    socket.fromfd(0, socket.AF_UNIX, socket.SOCK_SEQPACKET).shutdown(socket.SHUT_RDWR) # :P
+for signum in [signal.SIGINT, signal.SIGTERM]:
+    signal.signal(signum, sigterm)
+
 reqhandler = hclass(**hargs)
 try:
     ashd.util.serveloop(handle)
index fbb8d38..a63362d 100755 (executable)
@@ -1,6 +1,6 @@
 #!/usr/bin/python3
 
-import sys, os, getopt, socket, logging, time, locale, collections
+import sys, os, getopt, socket, logging, time, locale, collections, signal
 import ashd.util, ashd.serve
 try:
     import pdm.srv
@@ -197,6 +197,11 @@ except ValueError as exc:
     sys.stderr.write("ashd-wsgi3: %s\n" % exc)
     sys.exit(1)
 
+def sigterm(sig, frame):
+    socket.fromfd(0, socket.AF_UNIX, socket.SOCK_SEQPACKET).shutdown(socket.SHUT_RDWR) # :P
+for signum in [signal.SIGINT, signal.SIGTERM]:
+    signal.signal(signum, sigterm)
+
 reqhandler = hclass(**hargs)
 try:
     ashd.util.serveloop(handle)