mirror of
https://github.com/systemd/systemd.git
synced 2025-01-11 09:18:07 +03:00
nspawn: always use bind mounts to make API file systems available in the container
This ensures that read-only flags are never passed from the container to the host OS.
This commit is contained in:
parent
2eb916cdff
commit
f5c1b9eeb9
16
src/nspawn.c
16
src/nspawn.c
@ -124,15 +124,17 @@ static int mount_all(const char *dest) {
|
|||||||
} MountPoint;
|
} MountPoint;
|
||||||
|
|
||||||
static const MountPoint mount_table[] = {
|
static const MountPoint mount_table[] = {
|
||||||
{ "proc", "/proc", "proc", NULL, MS_NOSUID|MS_NOEXEC|MS_NODEV, true },
|
{ "/proc", "/proc", "bind", NULL, MS_BIND, true },
|
||||||
{ "/proc/sys", "/proc/sys", "bind", NULL, MS_BIND, true }, /* Bind mount first */
|
{ "/proc/sys", "/proc/sys", "bind", NULL, MS_BIND, true }, /* Bind mount first */
|
||||||
{ "/proc/sys", "/proc/sys", "bind", NULL, MS_BIND|MS_RDONLY|MS_REMOUNT, true }, /* Then, make it r/o */
|
{ "/proc/sys", "/proc/sys", "bind", NULL, MS_BIND|MS_RDONLY|MS_REMOUNT, true }, /* Then, make it r/o */
|
||||||
{ "sysfs", "/sys", "sysfs", NULL, MS_NOSUID|MS_NOEXEC|MS_NODEV|MS_RDONLY, true },
|
{ "/sys", "/sys", "bind", NULL, MS_BIND, true }, /* Bind mount first */
|
||||||
|
{ "/sys", "/sys", "bind", NULL, MS_BIND|MS_RDONLY|MS_REMOUNT, true }, /* Then, make it r/o */
|
||||||
{ "tmpfs", "/dev", "tmpfs", "mode=755", MS_NOSUID, true },
|
{ "tmpfs", "/dev", "tmpfs", "mode=755", MS_NOSUID, true },
|
||||||
{ "/dev/pts", "/dev/pts", "bind", NULL, MS_BIND, true },
|
{ "/dev/pts", "/dev/pts", "bind", NULL, MS_BIND, true },
|
||||||
{ "tmpfs", "/run", "tmpfs", "mode=755", MS_NOSUID|MS_NODEV, true },
|
{ "tmpfs", "/run", "tmpfs", "mode=755", MS_NOSUID|MS_NODEV, true },
|
||||||
#ifdef HAVE_SELINUX
|
#ifdef HAVE_SELINUX
|
||||||
{ "selinux", "/selinux", "selinuxfs", NULL, MS_NOSUID|MS_NOEXEC|MS_NODEV|MS_RDONLY, false },
|
{ "/selinux", "/selinux", "bind", NULL, MS_BIND, false }, /* Bind mount first */
|
||||||
|
{ "/selinux", "/selinux", "selinuxfs", NULL, MS_BIND|MS_RDONLY|MS_REMOUNT, false }, /* Then, make it r/o */
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -739,6 +741,10 @@ int main(int argc, char *argv[]) {
|
|||||||
if (prctl(PR_SET_PDEATHSIG, SIGKILL) < 0)
|
if (prctl(PR_SET_PDEATHSIG, SIGKILL) < 0)
|
||||||
goto child_fail;
|
goto child_fail;
|
||||||
|
|
||||||
|
/* Mark / as private, in case somebody marked it shared */
|
||||||
|
if (mount(NULL, "/", NULL, MS_PRIVATE|MS_REC, NULL) < 0)
|
||||||
|
goto child_fail;
|
||||||
|
|
||||||
if (mount_all(arg_directory) < 0)
|
if (mount_all(arg_directory) < 0)
|
||||||
goto child_fail;
|
goto child_fail;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user