X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=vserver-reference.init;h=56c4de5ead1aff86b156abcf7bfad555817adcd0;hb=5a949b31060abe2a1cc2d0437dced8dbb01f1026;hp=42263dfe699a86f2f61c426b34d8c3fb60e67f9e;hpb=5cf39d9bc2c8be3af2e560721ee1215a6e4e07c4;p=vserver-reference.git diff --git a/vserver-reference.init b/vserver-reference.init index 42263df..56c4de5 100755 --- a/vserver-reference.init +++ b/vserver-reference.init @@ -1,15 +1,15 @@ #!/bin/bash # -# vserver-reference Builds VServer reference +# vserver-reference Updates VServer reference # -# Load before pl_conf, pl_nm, vcached, and vservers +# Load before nm, vcached, and vservers # chkconfig: 3 60 80 # description: Builds VServer reference image # # Mark Huang # Copyright (C) 2004 The Trustees of Princeton University # -# $Id: vserver-reference.init,v 1.7 2004/11/29 20:19:13 mlhuang Exp $ +# $Id$ # case "$1" in @@ -36,109 +36,114 @@ exec 4>&2 # Redirect stdout and stderr to a log file exec 2>&1 -exec &>/var/log/vserver-reference.log - -# Make /vservers -mkdir -p $VROOTDIR -chmod 000 $VROOTDIR -$PKGLIBDIR/setattr --barrier $VROOTDIR - -# Build image in /vservers/.vtmp -mkdir -p $VROOTDIR/.vtmp -VROOT=$(mktemp -d $VROOTDIR/.vtmp/vserver-reference.XXXXXX) - -# Make /vservers/.vtmp/vserver-reference.XXXXXX -mkdir -p $VROOT -chmod 755 $VROOT - -echo -n $"Building VServer reference: " >&3 2>&4 - -# Clean up before exiting if anything goes wrong -trap "umount $VROOT/proc ; umount $VROOT/dev/pts ; rm -rf $VROOT ; failure >&3 2>&4 ; echo >&3 2>&4 ; exit 255" ERR - -MAKEDEV () -{ - rm -rf $VROOT/dev - mkdir -p $VROOT/dev - mknod -m 666 $VROOT/dev/null c 1 3 - mknod -m 666 $VROOT/dev/zero c 1 5 - mknod -m 666 $VROOT/dev/full c 1 7 - mknod -m 644 $VROOT/dev/random c 1 8 - mknod -m 644 $VROOT/dev/urandom c 1 9 - mknod -m 666 $VROOT/dev/tty c 5 0 - mknod -m 666 $VROOT/dev/ptmx c 5 2 - ln -nsf ../proc/self/fd /dev/fd - touch $VROOT/dev/hdv1 -} - -# Initialize /dev in reference image -MAKEDEV - -# Mount /dev/pts in reference image -mkdir -p $VROOT/dev/pts -mount -t devpts none $VROOT/dev/pts - -# Mount /proc in reference image -mkdir -p $VROOT/proc -mount -t proc none $VROOT/proc - -# Create a dummy /etc/fstab in reference image -mkdir -p $VROOT/etc -cat > $VROOT/etc/fstab < $VROOT/etc/rpm/macros <>/var/log/vserver-reference.log + +echo "--- STARTING $(date) ---" >&3 2>&4 + +# Parse PLC configuration +if [ -r /etc/planetlab/plc_config ] ; then + . /etc/planetlab/plc_config +else + PLC_NAME="PlanetLab" + PLC_SLICE_PREFIX="pl" + PLC_BOOT_HOST="boot.planet-lab.org" fi -# Install RPMs in reference image -yum $SSLCERTDIR --installroot=$VROOT -y groupinstall VServer +shopt -s nullglob + +# Make sure the barrier bit is set +chmod 0000 "$__DEFAULT_VSERVERDIR" +setattr --barrier "$__DEFAULT_VSERVERDIR" + +# Build reference images for system slices +# XXX Use Stork? +for lst in "$__DEFAULT_VSERVERDIR/system-packages/"*.lst ; do + NAME=$(basename $lst .lst) + + # Copy base reference image + if [ ! -d "$__DEFAULT_VSERVERDIR/.vref/$NAME" ] ; then + echo -n $"Building VServer reference image for $NAME: " >&3 2>&4 + + # Build in temporary directory + mkdir -p "$__DEFAULT_VSERVERDIR/.vtmp" + TMP=$(mktemp -d "$__DEFAULT_VSERVERDIR/.vtmp/$NAME.XXXXXX") + mkdir -p "$__DEFAULT_VSERVERDIR/.vref" + "$__PKGLIBDIR/vbuild" "$__DEFAULT_VSERVERDIR/.vref/default" "$TMP" + RETVAL=$? + + # Install/update additional packages + if [ $RETVAL -eq 0 ] ; then + pushd "$__DEFAULT_VSERVERDIR/system-packages" >/dev/null + xargs rpm --root "$TMP" --install < "$NAME.lst" + RETVAL=$? + popd >/dev/null + fi + + # Clean RPM state + rm -f "$TMP/var/lib/rpm/__db"* + + # Move it to its permanent location when complete + if [ $RETVAL -eq 0 ] ; then + mv "$TMP" "$__DEFAULT_VSERVERDIR/.vref/$NAME" + success >&3 2>&4 + else + failure >&3 2>&4 + fi + echo >&3 2>&4 + fi +done -# Clean up /dev in reference image -umount $VROOT/dev/pts -MAKEDEV +echo -n $"Updating VServer reference images: " >&3 2>&4 -# Disable all services in reference image -chroot $VROOT /bin/sh -c "chkconfig --list | awk '{ print \$1 }' | xargs -i chkconfig {} off" +VROOTS="$__DEFAULT_VSERVERDIR/.vref/* $__DEFAULT_VSERVERDIR/.vcache/* $__DEFAULT_VSERVERDIR/${PLC_SLICE_PREFIX}_*" -# Copy configuration files from host to reference image -for file in /etc/hosts /etc/resolv.conf /etc/yum.conf ; do - if [ -f $file ] ; then - echo $file | cpio -p -d -u $VROOT +# Copy configuration files from host to slices +for file in /etc/hosts /etc/resolv.conf /etc/yum.conf /etc/planetlab/node_id \ + /etc/planetlab/plc_config* /etc/planetlab/php/* \ + /etc/pki/rpm-gpg/* ; do + if [ -r $file ] ; then + for vroot in $VROOTS ; do + install -D -m 644 $file $vroot/$file + done fi done -# Clean up -umount $VROOT/proc +# Remove stale RPM locks +rm -f $vroot/var/lib/rpm/__db* -# Swap them when complete -mv $VROOT $VROOTDIR -if [ -d $VROOTDIR/vserver-reference ] ; then - mv $VROOTDIR/vserver-reference $VROOT - # Let vcached clean it up later +# (Re)install GPG signing keys +if [ -d /etc/pki/rpm-gpg ] ; then + for vroot in $VROOTS ; do + chroot $vroot rpm --allmatches -e gpg-pubkey || : + chroot $vroot rpm --import /etc/pki/rpm-gpg/* || : + done fi -mv $VROOTDIR/$(basename $VROOT) $VROOTDIR/vserver-reference -# Disable again -chkconfig vserver-reference off +# Old versions of the Boot Manager copied portions of the Boot CD to +# /mnt/cdrom/bootme, to support old scripts which assumed that the +# Boot CD was mounted even in production mode. Now, it just copies it +# to /usr/boot/cacert.pem. In any case, copy the boot server +# certificate to the place(s) where BootServerRequest expects to find +# it (/usr/boot/cacert.pem by default, /mnt/cdrom/bootme in old +# versions). +CACERT="/usr/boot/cacert.pem /mnt/cdrom/bootme/cacert/$PLC_BOOT_HOST/cacert.pem" +for cacert in $CACERT ; do + if [ -r $cacert ] ; then + for vroot in $VROOTS ; do + # Install boot server certificate + install -D -m 644 $cacert $vroot/usr/boot/cacert.pem + echo $PLC_BOOT_HOST > $vroot/usr/boot/boot_server + + # Also install in /mnt/cdrom/bootme for backward compatibility + install -D -m 644 $cacert $vroot/mnt/cdrom/bootme/cacert/$PLC_BOOT_HOST/cacert.pem + echo $PLC_BOOT_HOST > $vroot/mnt/cdrom/bootme/BOOTSERVER + done + break + fi +done success >&3 2>&4 +echo "--- DONE $(date) ---" >&3 2>&4 echo >&3 2>&4 + exit 0