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