deploy multiple vnets with VIMAGE/VNET + Production Ready?
Ernie Luzar
luzar722 at gmail.com
Thu Jun 2 22:05:25 UTC 2016
Michael Grimm wrote:
> Sebastián Maruca via freebsd-jail <freebsd-jail at freebsd.org> wrote:
>
>> Now we're talking about 10.3-HEAD wiht Jails+vnet... but then again, has anyone tried it? Roger, it seems you are thumbing up my challenge...
>> But I guess i'll have to stick with netgraph instead epair/if_bridge because the later is not so documented as the first one…
>
> Preamble: I switched to VNET+epair/if_bridge jails starting 10.2-STABLE, now 10.3-STABLE, and haven't seen any issues, sofar. Currently I do have 10 jails running, firewall is pf at the host, only. My servers are not big scaled ISP like, more small business-like, though. I am considering myself a hobby admin.
>
>
> Here's my configuration that may show you one way to get that running, but I am sure your will have to tweak it to your needs:
>
> 1) Jails have been created by ezjail in the past, thus they are still at ezjail's infrastructure. But I do no longer use ezjail for starting or stopping my jails due to ezjail's lack of dealing with VNET jails (yet). So I do still have fstab definitions in /etc for all jails, e.g.:
>
> /etc/fstab.www
> /path-to-your/jails/basejail /path-to-your/jails/www/basejail nullfs ro 0 0
>
> 2) All external IPv4 or IPv6 addresses are NAT'ed or NAT66'ed to 10.1.1.x or fd00:dead:dead:beef::x
>
> 3) Networking regarding VNET jails defined in /etc/rc.conf:
>
> # set up one bridge interface
> cloned_interfaces="bridge0"
>
> # needed for default routes within jails
> ifconfig_bridge0="inet 10.1.1.254 netmask 255.255.255.0"
> ifconfig_bridge0_ipv6="inet6 fd00:dead:dead:beef::254 prefixlen 64"
>
> 4) Thus, jails are controlled by jail(8) (shown for 3 example jails):
>
> /etc/rc.conf
> ———————————————BEGIN------------------------
> jail_enable="YES"
> jail_reverse_stop="YES"
> jail_list="dns www mail"
> ———————————————-END————————————
>
> /etc/jail.conf:
> #
> # host dependent global settings
> #
> $ip6prefixLOCAL = "fd00:dead:dead:beef";
>
> #
> # global jail settings
> #
> host.hostname = "${name}";
> path = "/path-to-your/jails/${name}";
> mount.fstab = "/etc/fstab.${name}";
> exec.consolelog = "/var/log/jail_${name}_console.log";
> vnet = "new";
> vnet.interface = "epair${jailID}b";
> exec.clean;
> mount.devfs;
> persist;
>
> #
> # network settings to apply/destroy during start/stop of every jail
> #
> exec.prestart = "sleep 2";
> exec.prestart += "ifconfig epair${jailID} create up";
> exec.prestart += "ifconfig bridge0 addm epair${jailID}a";
> exec.start = "/sbin/ifconfig lo0 127.0.0.1 up";
> exec.start += "/sbin/ifconfig epair${jailID}b inet ${ip4_addr}";
> exec.start += "/sbin/ifconfig epair${jailID}b inet6 ${ip6_addr}";
> exec.start += "/sbin/route add default -gateway 10.1.1.254";
> exec.start += "/sbin/route add -inet6 default -gateway ${ip6prefixLOCAL}::254";
> #exec.stop = "/sbin/route del default";
> #exec.stop += "/sbin/route del -inet6 default";
> exec.stop += "/bin/sh /etc/rc.shutdown";
> exec.poststop = "ifconfig epair${jailID}a destroy";
>
> #
> # individual jail settings
> #
> mail {
> $jailID = 1;
> $ip4_addr = 10.1.1.1;
> $ip6_addr = ${ip6prefixLOCAL}::1/64;
> exec.start += "/bin/sh /etc/rc";
> }
>
> www {
> $jailID = 2;
> $ip4_addr = 10.1.1.2;
> $ip6_addr = ${ip6prefixLOCAL}::2/64;
> exec.start += "/bin/sh /etc/rc";
> }
>
> dns {
> $jailID = 3;
> $ip4_addr = 10.1.1.3;
> $ip4_addr_2 = 10.1.1.4;
> $ip6_addr = ${ip6prefixLOCAL}::3/64;
> $ip6_addr_2 = ${ip6prefixLOCAL}::4/64;
> exec.start += "/sbin/ifconfig epair${jailID}b inet ${ip4_addr_2} alias";
> exec.start += "/sbin/ifconfig epair${jailID}b inet6 ${ip6_addr_2} alias";
> exec.start += "/bin/sh /etc/rc";
> }
>
> Now you can use "service jail" to start/stop your jails, e.g.:
>
> service jail stop
> service jail restart dns
> service jail start dns mail
>
> 5) NOTE: I am refraining from restarting VNET jails the hard way as shown above, and I am using a similar approach as iocage, namely "soft restarts". As this functionality isn't available in 10.3-STABLE (IIRC) I am using a homemade shell script instead. This script has to be run *inside* a jail which can be triggered from the outside (still using ezjail-admin) by e.g.: "sudo ezjail-admin console -e '/usr/local/etc/_JAIL_SOFT_RESTART' www"
>
> #!/bin/csh
>
> #
> # restart jail services without removing jail and its network
> #
>
> #
> # global definitions
> #
> set LOGGER = "/usr/bin/logger -p user.info -t _JAIL_SOFT_RC"
> set RCDIR = "/usr/local/etc/rc.d"
> set TAB = " "
>
> #
> # evaluate list of rc files in /usr/local/etc/rc.d
> #
> set RCFILES = `rcorder ${RCDIR}/* |& grep -v ^rcorder:`
>
> #
> # evaluate reverse order of RCFILES
> #
> set RCFILES_REVERSE = ""
> foreach rcname ( ${RCFILES} )
> set RCFILES_REVERSE = "${rcname} ${RCFILES_REVERSE}"
> end
>
> #
> # stop rc services
> #
> echo "stopping:"
> foreach rcname ( ${RCFILES_REVERSE} )
> ${LOGGER} stopping ${rcname}
> ${rcname} stop >& /dev/null
> echo "${TAB}" ${rcname}
> end
>
> #
> # start rc services
> #
> echo "starting:"
> foreach rcname ( ${RCFILES} )
> ${LOGGER} starting ${rcname}
> ${rcname} start >& /dev/null
> echo "${TAB}" ${rcname}
> end
>
> exit 0
>
> This script isn't perfect, and if you start or stop a jail you need to separate the relevant part. This can easily be coded into that script, I know. But I was lazy ;-)
>
> I hope that helps for a start. Again, I am sure you may need some tweaking at your site.
>
> Regards,
> Michael
>
>
Michael,
You left out whether you had to compile the kernel with the vimage
option or whether vimage was already included in the kernel?
More information about the freebsd-jail
mailing list