41a6c3
From 20656c3b77cc548b59fea3bde5e2b7705d71c427 Mon Sep 17 00:00:00 2001
41a6c3
From: =?UTF-8?q?Jan=20Kalu=C5=BEa?= <jkaluza@apache.org>
41a6c3
Date: Mon, 18 Aug 2014 07:43:43 +0000
41a6c3
Subject: [PATCH] prefork: Ignore SIGINT in child. This fixes race-condition in
41a6c3
 signals handling when httpd is runnning on foreground and user hits ctrl+c.
41a6c3
 In this case, SIGINT is sent to all children followed by SIGTERM from the
41a6c3
 main process, which interrupts the SIGINT handler and leads to inconsistency
41a6c3
 (process freezes or crashes).
41a6c3
41a6c3
git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1618555 13f79535-47bb-0310-9956-ffa450edef68
41a6c3
---
41a6c3
 server/mpm/prefork/prefork.c | 10 ++++++++++
41a6c3
 1 file changed, 10 insertions(+)
41a6c3
41a6c3
diff --git a/server/mpm/prefork/prefork.c b/server/mpm/prefork/prefork.c
41a6c3
index 8790ec0..d6c038b 100644
41a6c3
--- a/server/mpm/prefork/prefork.c
41a6c3
+++ b/server/mpm/prefork/prefork.c
41a6c3
@@ -222,6 +222,9 @@ static void clean_child_exit(int code)
41a6c3
 {
41a6c3
     mpm_state = AP_MPMQ_STOPPING;
41a6c3
 
41a6c3
+    apr_signal(SIGHUP, SIG_IGN);
41a6c3
+    apr_signal(SIGTERM, SIG_IGN);
41a6c3
+
41a6c3
     if (pchild) {
41a6c3
         apr_pool_destroy(pchild);
41a6c3
     }
41a6c3
@@ -817,6 +820,13 @@ static int make_child(server_rec *s, int slot)
41a6c3
          */
41a6c3
         apr_signal(SIGHUP, just_die);
41a6c3
         apr_signal(SIGTERM, just_die);
41a6c3
+        /* Ignore SIGINT in child. This fixes race-condition in signals
41a6c3
+         * handling when httpd is runnning on foreground and user hits ctrl+c.
41a6c3
+         * In this case, SIGINT is sent to all children followed by SIGTERM
41a6c3
+         * from the main process, which interrupts the SIGINT handler and
41a6c3
+         * leads to inconsistency.
41a6c3
+         */
41a6c3
+        apr_signal(SIGINT, SIG_IGN);
41a6c3
         /* The child process just closes listeners on AP_SIG_GRACEFUL.
41a6c3
          * The pod is used for signalling the graceful restart.
41a6c3
          */
41a6c3
-- 
41a6c3
2.0.4
41a6c3