summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--CHANGES3
-rw-r--r--os/unix/unixd.c15
2 files changed, 12 insertions, 6 deletions
diff --git a/CHANGES b/CHANGES
index 09343fa05e..f55f0feea6 100644
--- a/CHANGES
+++ b/CHANGES
@@ -1,6 +1,9 @@
-*- coding: utf-8 -*-
Changes with Apache 2.5.1
+ *) core: In ONE_PROCESS/debug mode, cleanup everything when exiting.
+ [Yann Ylavic]
+
*) mod_http2: restoring the v1.10.16 keepalive timeout behavioud of mod_http2 (to be verified).
[Stefan Eissing]
diff --git a/os/unix/unixd.c b/os/unix/unixd.c
index 196f67bace..bde859022b 100644
--- a/os/unix/unixd.c
+++ b/os/unix/unixd.c
@@ -532,12 +532,15 @@ AP_DECLARE(void) ap_unixd_mpm_set_signals(apr_pool_t *pconf, int one_process)
if (!one_process) {
ap_fatal_signal_setup(ap_server_conf, pconf);
}
- else {
- static int once = 0;
- if (!once) {
- atexit(ap_terminate);
- once = 1;
- }
+ else if (!ap_retained_data_get("ap_unixd_mpm_one_process_cleanup")) {
+ /* In one process mode (debug), httpd will exit immediately when asked
+ * to (SIGTERM/SIGINT) and never restart. We still want the cleanups to
+ * run though (such that e.g. temporary files/IPCs don't leak on the
+ * system), so the first time around we use atexit() to cleanup after
+ * ourselves.
+ */
+ ap_retained_data_create("ap_unixd_mpm_one_process_cleanup", 1);
+ atexit(ap_terminate);
}
/* Signals' handlers depend on retained data */