exec_poststart

James Gritton jamie at gritton.org
Mon Feb 8 22:57:42 UTC 2016


On 2016-02-05 16:01, markham breitbach wrote:
> I am trying to figure out how to get a script to figure out the 
> hostname
> of the jail that is starting without having to manual set that as a
> command line parameter (as illustrated).  It seems that the script is
> getting executed in a clean environment, regardless of the exec.clean
> setting.  Is this a bug?  The man pages aren't particularly clear on 
> the
> expected behaviour of this.  I am running FreeBSD 10.2.
> 
> I would like to be able to set exec.poststart as a global default so it
> doesn't need to be defined per jail.
> 
> Thanks,
> -Markham
> 
> ####################JAIL.CONF#########################
> exec.clean = 0 ;
> 
> # HOW TO PASS THE JAILNAME TO THIS SCRIPT?
> exec.poststart += "/path/to/script.sh";
> 
> # My test jail
> testjail_example_com {
>     # THIS WORKS
>     exec.poststart += "/path/to/script.sh testjail.example.com";
>     exec.clean = 0 ;
>     host.hostname = "testjail.example.com";
>     path = "/usr/jails/testjail.example.com";
>     ip4.addr += "net0|192.0.2.1/24";
>     exec.system_user = "root";
>     exec.jail_user = "root";
>     exec.start += "/bin/sh /etc/rc";
>     exec.stop = "";
>     exec.consolelog = "/var/log/jail_testjail_example_com_console.log";
>     mount.fstab = "/etc/testjail_example_com";
>     mount.devfs;
>     devfs_ruleset = "5";
>     mount.fdescfs;
>     mount.procfs;
>     allow.mount;
>     allow.set_hostname = 0;
>     allow.sysvipc = 0;
>     allow.raw_sockets=1;
> }

You can reference jail parameters within other parameters, much like 
you'd use shell variables.  In the global part of the definition, you 
can set:

exec.poststart = "/path/to/script.sh ${host.hostname}"

Then you won't need to define a separate exec.poststart within each 
jail.  Note you can also do this with the path parameter, since your 
path is based on the hostname.  And exec.consolelog and mount.fstab are 
based on the jail name, so you can similarly globally set something like 
mount.fstab = "/etc/$name".

exec.clean=0 should indeed avoid scrubbing the environment, but note 
that if your jail starts by running /etc/rc, the top of rc will reset at 
least the path on its own, probably other stuff as well.

- Jamie


More information about the freebsd-jail mailing list