From f5b8ea9128fbafaf60c2de31a314f008819c48aa Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kristj=C3=A1n=20Valur=20J=C3=B3nsson?= Date: Sun, 5 Jul 2009 20:56:57 +0000 Subject: [PATCH] http://bugs.python.org/issue6382 close_request() (which can send a socket.shutdown()) must be called by the child process in a forking server. The parent must merely close the socket handle. --- Lib/SocketServer.py | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/Lib/SocketServer.py b/Lib/SocketServer.py index 08f005b0864..20b8203dbe7 100644 --- a/Lib/SocketServer.py +++ b/Lib/SocketServer.py @@ -532,17 +532,19 @@ class ForkingMixIn: if self.active_children is None: self.active_children = [] self.active_children.append(pid) - self.close_request(request) + request.close() #close socket handle in parent process return else: # Child process. # This must never return, hence os._exit()! try: self.finish_request(request, client_address) + self.close_request(request) os._exit(0) except: try: self.handle_error(request, client_address) + self.close_request(request) finally: os._exit(1)