[Lxc-users] lxc-start leaves temporary pivot dir behind

Daniel Lezcano daniel.lezcano at free.fr
Wed May 5 13:57:51 UTC 2010


Ferenc Wagner wrote:
> Hi,
>
> While playing with lxc-start, I noticed that /tmp is infested by empty
> lxc-r* directories:
>
> # lxc-start --logfile=/tmp/startlog --logpriority=DEBUG -n jail -s lxc.mount.entry="/ /tmp/jail none bind 0 0" -s lxc.rootfs=/tmp/jail -s lxc.pivotdir=/mnt ls /proc
> # cat /tmp/startlog
>       lxc-start 1273064291.740 DEBUG    lxc_start - sigchild handler set
>       lxc-start 1273064291.740 INFO     lxc_start - 'jail' is initialized
>       lxc-start 1273064291.745 DEBUG    lxc_cgroup - using cgroup mounted at '/cgroup'
>       lxc-start 1273064291.745 DEBUG    lxc_cgroup - '/cgroup/3178' renamed to '/cgroup/jail'
>       lxc-start 1273064291.746 DEBUG    lxc_conf - mounted / on /tmp/jail, type none
>       lxc-start 1273064291.746 INFO     lxc_conf - mount points have been setup
>       lxc-start 1273064291.746 WARN     lxc_conf - rootfs specified but no console found
>       lxc-start 1273064291.746 INFO     lxc_conf - 0 tty(s) has been setup
>       lxc-start 1273064291.746 DEBUG    lxc_conf - temporary mountpoint for old rootfs is './mnt'
>       lxc-start 1273064291.746 DEBUG    lxc_conf - pivot_root syscall to '/mnt' successful
>       lxc-start 1273064291.746 DEBUG    lxc_conf - umounted '/mnt/dev/pts'
>       lxc-start 1273064291.746 DEBUG    lxc_conf - umounted '/mnt/dev/shm'
>       lxc-start 1273064291.746 DEBUG    lxc_conf - umounted '/mnt/sys'
>       lxc-start 1273064291.746 DEBUG    lxc_conf - umounted '/mnt/proc'
>       lxc-start 1273064291.747 DEBUG    lxc_conf - umounted '/mnt/lib/init/rw'
>       lxc-start 1273064291.747 DEBUG    lxc_conf - umounted '/mnt/var/run'
>       lxc-start 1273064291.747 DEBUG    lxc_conf - umounted '/mnt/var/lock'
>       lxc-start 1273064291.747 DEBUG    lxc_conf - umounted '/mnt/cgroup'
>       lxc-start 1273064291.747 DEBUG    lxc_conf - umounted '/mnt/tmp/jail'
>       lxc-start 1273064291.747 DEBUG    lxc_conf - umounted '/mnt/dev'
>       lxc-start 1273064291.747 DEBUG    lxc_conf - umounted '/mnt/tmp'
>       lxc-start 1273064291.747 DEBUG    lxc_conf - umounted '/mnt'
>       lxc-start 1273064291.747 INFO     lxc_conf - pivoted to '/tmp/lxc-rX4K9le'
>       lxc-start 1273064291.748 DEBUG    lxc_conf - capabilities has been setup
>       lxc-start 1273064291.748 NOTICE   lxc_conf - 'jail' is setup.
>       lxc-start 1273064291.748 NOTICE   lxc_start - exec'ing 'ls'
>       lxc-start 1273064291.753 NOTICE   lxc_start - 'ls' started with pid '3178'
>       lxc-start 1273064291.753 INFO     lxc_console - no console specified
>       lxc-start 1273064291.753 WARN     lxc_utmp - '/tmp/jail/var/run/utmp' not found
>       lxc-start 1273064291.763 DEBUG    lxc_start - child exited
>       lxc-start 1273064291.763 DEBUG    lxc_cgroup - using cgroup mounted at '/cgroup'
>       lxc-start 1273064291.764 DEBUG    lxc_cgroup - '/cgroup/jail' unlinked
>
> And /tmp/lxc-rX4K9le is left behind...  Ok, this name comes from
> lxc-rootfs in conf.c:setup_rootfs.  After setup_rootfs_pivot_root
> returns, the original /tmp is not available anymore, so rmdir(tmpname)
> at the bottom of setup_rootfs can't achieve much.  Why is this temporary
> name needed anyway?  Is pivoting impossible without it?  I can't see why.
>   
That was put in place with chroot, before pivot_root, so the distro's 
scripts can remount their '/' without failing.

Now we have pivot_root, I suppose we can change that to something cleaner...




More information about the lxc-users mailing list