Mount order for ZFS, jails, and nullfs
Torbjorn Granlund
tg at gmplib.org
Fri Sep 24 16:03:09 UTC 2010
In jails, I'd like a local ZFS /, a read-only nullfs-mounted /usr, and a
local /usr/local. (I'd also have read-only nullfs-mounted /bin, /lib,
/libexec, but let's forget about that for now.)
This way, I can upgrade the master /usr once, in one place, and have all
jails inherit it. And my dear jail inmates can install anything in
/usr/local (such as their favourite packages/ports).
I.e., things should look like this:
/myjail/ zfs
/myjail/usr nullfs ro
/myjail/usr/local zfs
There is no problem to make this happen by issuing a handful of commands
manually after boot, but I cannot seem to get it to work automatically,
with existing boot mechanism. The problem is that the mount of /usr
will be attempted before ZFS has mounted /myjail, the jail's root.
ZFS maintains its own mount table. It is possible to disable the
automated mounting in ZFS by specifying the pseudo mountpoint "legacy",
and then--according to the FreeBSD manual--mount it with mount(8).
Unfortunately, FreeBSD's mount seems unable to perform mounts of ZFS
volumes.
How can I achieve the result I want after a reboot?
(The reply "use ezjail!" is not the right one. :-) It does not do what
I want to do. I dislike its symlink forest, and that it creates just
one ZFS filesystem for the entire jail.)
--
Torbjörn
More information about the freebsd-questions
mailing list