journal: in persistent mode create /var/log/journal, with all parents.
authorDimitri John Ledkov <dimitri.j.ledkov@intel.com>
Fri, 3 Jul 2015 10:34:12 +0000 (11:34 +0100)
committerDimitri John Ledkov <dimitri.j.ledkov@intel.com>
Fri, 3 Jul 2015 16:16:09 +0000 (17:16 +0100)
systemd-journald races with systemd-tmpfiles-setup, and hence both are
started at about the same time. On a bare-bones system (e.g. with
empty /var, or even non-existent /var), systemd-tmpfiles will create
/var/log. But it can happen too late, that is systemd-journald already
attempted to mkdir /var/log/journal, ignoring the error. Thus failing
to create /var/log/journal. One option, without modifiying the
dependency graph is to create /var/log/journal directory with parents,
when persistent storage has been requested.

src/journal/journald-server.c

index f740298..46358e1 100644 (file)
@@ -943,7 +943,7 @@ static int system_journal_open(Server *s, bool flush_requested) {
                  * the machine path */
 
                 if (s->storage == STORAGE_PERSISTENT)
-                        (void) mkdir("/var/log/journal/", 0755);
+                        (void) mkdir_p("/var/log/journal/", 0755);
 
                 fn = strjoina("/var/log/journal/", ids);
                 (void) mkdir(fn, 0755);