Blame SOURCES/0388-journald-dispatch-SIGTERM-SIGINT-with-a-low-priority.patch

17b0f1
From be21e10cf30e66215e986ab900637b32e502a29a Mon Sep 17 00:00:00 2001
17b0f1
From: Lennart Poettering <lennart@poettering.net>
17b0f1
Date: Tue, 10 Nov 2015 16:53:00 +0100
17b0f1
Subject: [PATCH] journald: dispatch SIGTERM/SIGINT with a low priority
17b0f1
17b0f1
Let's make sure to process all queued log data before exiting, so that
17b0f1
we don't unnecessary lose messages when shutting down.
17b0f1
17b0f1
https://github.com/systemd/systemd/pull/1812#issuecomment-155149871
17b0f1
17b0f1
Cherry-picked from: b374689c02c681671a3c3c0b0fd3add32386b442
17b0f1
Related: #1318994
17b0f1
---
17b0f1
 src/journal/journald-server.c | 12 ++++++++++++
17b0f1
 1 file changed, 12 insertions(+)
17b0f1
17b0f1
diff --git a/src/journal/journald-server.c b/src/journal/journald-server.c
17b0f1
index 275224dc99..2b7ecd09ab 100644
17b0f1
--- a/src/journal/journald-server.c
17b0f1
+++ b/src/journal/journald-server.c
17b0f1
@@ -1284,10 +1284,22 @@ static int setup_signals(Server *s) {
17b0f1
         if (r < 0)
17b0f1
                 return r;
17b0f1
 
17b0f1
+        /* Let's process SIGTERM late, so that we flush all queued
17b0f1
+         * messages to disk before we exit */
17b0f1
+        r = sd_event_source_set_priority(s->sigterm_event_source, SD_EVENT_PRIORITY_NORMAL+20);
17b0f1
+        if (r < 0)
17b0f1
+                return r;
17b0f1
+
17b0f1
+        /* When journald is invoked on the terminal (when debugging),
17b0f1
+         * it's useful if C-c is handled equivalent to SIGTERM. */
17b0f1
         r = sd_event_add_signal(s->event, &s->sigint_event_source, SIGINT, dispatch_sigterm, s);
17b0f1
         if (r < 0)
17b0f1
                 return r;
17b0f1
 
17b0f1
+        r = sd_event_source_set_priority(s->sigint_event_source, SD_EVENT_PRIORITY_NORMAL+20);
17b0f1
+        if (r < 0)
17b0f1
+                return r;
17b0f1
+
17b0f1
         return 0;
17b0f1
 }
17b0f1