X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sliver_lxc.py;h=f7019649c91f63ad0ae26753531226987b8cf496;hb=931588ce80de75383b980a3eab806a60396364ba;hp=bdfd71df9f3869adc32ca9a56c7509a572d3835f;hpb=017b153a7cfd73df8cbbc1b7ecbfd7def0a66d0d;p=nodemanager.git diff --git a/sliver_lxc.py b/sliver_lxc.py index bdfd71d..f701964 100644 --- a/sliver_lxc.py +++ b/sliver_lxc.py @@ -87,7 +87,7 @@ class Sliver_LXC(Sliver_Libvirt, Initscript): # subvolume) command = ['btrfs', 'subvolume', 'snapshot', refImgDir, containerDir] if not logger.log_call(command, timeout=15*60): - logger.log('sliver_lxc: ERROR Could not create BTRFS snapshot at', containDir) + logger.log('sliver_lxc: ERROR Could not create BTRFS snapshot at', containerDir) return command = ['chmod', '755', containerDir] logger.log_call(command, timeout=15*60) @@ -97,10 +97,27 @@ class Sliver_LXC(Sliver_Libvirt, Initscript): ld_preload_msg="""# by default, we define this setting so that calls to bind(2), # when invoked on 0.0.0.0, get transparently redirected to the public interface of this node # see https://svn.planet-lab.org/wiki/LxcPortForwarding""" + usrmove_path_msg="""# VM's before Features/UsrMove need /bin and /sbin in their PATH""" + usrmove_path_code=""" +pathmunge () { + if ! echo $PATH | /bin/egrep -q "(^|:)$1($|:)" ; then + if [ "$2" = "after" ] ; then + PATH=$PATH:$1 + else + PATH=$1:$PATH + fi + fi +} +pathmunge /bin after +pathmunge /sbin after +unset pathmunge +""" with open(dot_profile,'w') as f: f.write("export PS1='%s@\H \$ '\n"%(name)) f.write("%s\n"%ld_preload_msg) f.write("export LD_PRELOAD=/etc/planetlab/lib/bind_public.so\n") + f.write("%s\n"%usrmove_path_msg) + f.write("%s\n"%usrmove_path_code) # TODO: set quotas...