X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=build.sh;h=c4c117e61e1c78269147f84a2147925e64b45a09;hb=ea0f8131c3a4fd50c7c72d0a506533167ac51648;hp=28e23c3ccf4c2f1a64c8968b5951c43a5c7039cb;hpb=7ae0f333a6122939d191fe257ca617d5099a6db9;p=vserver-reference.git diff --git a/build.sh b/build.sh index 28e23c3..c4c117e 100755 --- a/build.sh +++ b/build.sh @@ -38,8 +38,7 @@ shiftcount=$? shift $shiftcount # pldistro expected as $1 - defaults to planetlab -pldistro=planetlab -[ -n "$@" ] && pldistro=$1 +pldistro=$1 ; shift # Do not tolerate errors set -e @@ -56,16 +55,17 @@ vrefname=default vref=${vrefdir}/${vrefname} install -d -m 755 ${vref} -# locate the packages and groups file -pkgsfile=$(pl_locateDistroFile ../build/ ${pldistro} vserver.pkgs) - # Some of the PlanetLab RPMs attempt to (re)start themselves in %post, # unless the installation is running inside the BootCD environment. We # would like to pretend that we are. export PL_BOOTCD=1 # Populate image with vserver-reference packages -pl_root_setup_chroot ${vref} -k -f $pkgsfile +pl_root_makedevs ${vref} +# locate the packages and groups file +pkgsfile=$(pl_locateDistroFile ../build/ ${pldistro} vserver.pkgs) +pl_root_mkfedora ${vref} ${pldistro} $pkgsfile +pl_root_tune_image ${vref} systemvserver_count=$(ls ../build/config.${pldistro}/vserver-*.pkgs 2> /dev/null | wc -l) [ $systemvserver_count -gt 0 ] && for systemvserver in $(ls ../build/config.${pldistro}/vserver-*.pkgs) ; do @@ -74,8 +74,8 @@ systemvserver_count=$(ls ../build/config.${pldistro}/vserver-*.pkgs 2> /dev/null echo "--------START BUILDING system vserver ${NAME}: $(date)" # "Parse" out the packages and groups for yum - systempackages=$(pl_getPackages ${pl_DISTRO_NAME} $systemvserver) - systemgroups=$(pl_getGroups ${pl_DISTRO_NAME} $systemvserver) + systempackages=$(pl_getPackages ${pl_DISTRO_NAME} $pldistro $systemvserver) + systemgroups=$(pl_getGroups ${pl_DISTRO_NAME} $pldistro $systemvserver) vdir=${vstubdir}/${NAME} rm -rf ${vdir}/* @@ -92,10 +92,10 @@ systemvserver_count=$(ls ../build/config.${pldistro}/vserver-*.pkgs 2> /dev/null [ -n "$systempackages" ] && yum -c ${vdir}/etc/yum.conf --installroot=${vdir} -y install $systempackages [ -n "$systemgroups" ] && yum -c ${vdir}/etc/yum.conf --installroot=${vdir} -y groupinstall $systemgroups - pkgsdir=$(dirname $pkgsfile) - pkgsname=$(basename $pkgsfile .pkgs) - postfile="${pkgsdir}/${pkgsname}.post" - [ -f $postfile ] && /bin/bash $postfile ${vdir} || : + pkgsdir=$(dirname $pkgsfile) + pkgsname=$(basename $pkgsfile .pkgs) + postfile="${pkgsdir}/${pkgsname}.post" + [ -f $postfile ] && /bin/bash $postfile ${vdir} || : # Create a copy of the system vserver w/o the vserver reference files and make it smaller. # This is a three step process: @@ -103,6 +103,8 @@ systemvserver_count=$(ls ../build/config.${pldistro}/vserver-*.pkgs 2> /dev/null # step 1: clean out yum cache to reduce space requirements yum -c ${vdir}/etc/yum.conf --installroot=${vdir} -y clean all + [ -f ${vdir}/etc/yum.conf.rpmnew ] && mv -f ${vdir}/etc/yum.conf.rpmnew ${vdir}/etc/yum.conf + # step 2: figure out the new/changed files in ${vdir} vs. ${vref} and compute ${vdir}.changes rsync -anv ${vdir}/ ${vref}/ > ${vdir}.changes linecount=$(wc -l ${vdir}.changes | awk ' { print $1 } ') @@ -126,4 +128,12 @@ systemvserver_count=$(ls ../build/config.${pldistro}/vserver-*.pkgs 2> /dev/null echo "--------DONE BUILDING system vserver ${NAME}: $(date)" done +pkgsdir=$(dirname $pkgsfile) +pkgsname=$(basename $pkgsfile .pkgs) +postfile="${pkgsdir}/${pkgsname}.post" +[ -f $postfile ] && /bin/bash $postfile ${vref} || : + +# switch the vserver reference /etc/yum.conf to the new one from the yum package +[ -f ${vref}/etc/yum.conf.rpmnew ] && mv -f ${vref}/etc/yum.conf.rpmnew ${vref}/etc/yum.conf + exit 0