]> git.ipfire.org Git - thirdparty/lxc.git/commitdiff
rootfs pinning: On NFS, make file hidden but don't delete it 2259/head
authorGuido Jäkel <g.jaekel@dnb.de>
Fri, 6 Apr 2018 07:35:21 +0000 (09:35 +0200)
committerGitHub <noreply@github.com>
Fri, 6 Apr 2018 07:35:21 +0000 (09:35 +0200)
On NFS, avoid random names of the root pin file due to "NFS silly renaming" but use a fixed hidden name instead.

src/lxc/conf.c

index 7455843086c543d6219dcbcfcb9093bd73e61da2..6e0b06a00289279330bbf12d3f2af6f79c5027c3 100644 (file)
@@ -539,10 +539,11 @@ int run_script(const char *name, const char *section, const char *script, ...)
 }
 
 /* pin_rootfs
- * if rootfs is a directory, then open ${rootfs}/lxc.hold for writing for
+ * if rootfs is a directory, then open ${rootfs}/.lxc-keep for writing for
  * the duration of the container run, to prevent the container from marking
  * the underlying fs readonly on shutdown. unlink the file immediately so
- * no name pollution is happens
+ * no name pollution is happens.
+ * don't unlink on NFS to avoid random named stale handles.
  * return -1 on error.
  * return -2 if nothing needed to be pinned.
  * return an open fd (>=0) if we pinned it.
@@ -552,6 +553,7 @@ int pin_rootfs(const char *rootfs)
        int fd, ret;
        char absrootfs[MAXPATHLEN], absrootfspin[MAXPATHLEN];
        struct stat s;
+       struct statfs sfs;
 
        if (rootfs == NULL || strlen(rootfs) == 0)
                return -2;
@@ -570,7 +572,7 @@ int pin_rootfs(const char *rootfs)
        if (!S_ISDIR(s.st_mode))
                return -2;
 
-       ret = snprintf(absrootfspin, MAXPATHLEN, "%s/lxc.hold", absrootfs);
+       ret = snprintf(absrootfspin, MAXPATHLEN, "%s/.lxc-keep", absrootfs);
        if (ret >= MAXPATHLEN)
                return -1;
 
@@ -578,6 +580,15 @@ int pin_rootfs(const char *rootfs)
        if (fd < 0)
                return fd;
 
+       if (fstatfs (fd, &sfs)) {
+               return -1;
+       }
+
+       if (sfs.f_type == NFS_SUPER_MAGIC) {
+               DEBUG("rootfs on NFS, not unlinking pin file \"%s\".", absrootfspin);
+               return fd;
+       }
+
        (void)unlink(absrootfspin);
 
        return fd;