X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=vserver-reference.spec;h=477667ceb92b251a246b29d6b92d970f0f27efe1;hb=b0014ac63a0b8dc606d2ca38fab8ad4058294942;hp=14eed93cc0e7d1c836b409c8b373dd6a05ef43ea;hpb=39ebc061d62e884542c8e5076a6359636f2bdd7f;p=vserver-reference.git diff --git a/vserver-reference.spec b/vserver-reference.spec index 14eed93..477667c 100644 --- a/vserver-reference.spec +++ b/vserver-reference.spec @@ -1,6 +1,6 @@ -%define name vserver-reference -%define version 3.0 -%define release 5.planetlab%{?date:.%{date}} +%define name vserver +%define version 3.1 +%define release 3%{?pldistro:.%{pldistro}}%{?date:.%{date}} Vendor: PlanetLab Packager: PlanetLab Central @@ -15,34 +15,105 @@ Source0: %{name}-%{version}.tar.bz2 License: GPL Group: Applications/System BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-buildroot -BuildArchitectures: noarch -Requires: util-vserver, e2fsprogs, yum +Requires: util-vserver, e2fsprogs, yum, coreutils + +%define debug_package %{nil} %description +This package does not really exist. + +%package reference +Summary: VServer reference image +Group: Applications/System +AutoReqProv: no + +%description reference This package creates the virtual server (VServer) reference image used as the installation base for new PlanetLab slivers. +%package system-packages +Summary: System slice packages +Group: Applications/System +Requires: vserver-reference = %{version}-%{release} +AutoReqProv: no + +%description system-packages +This package installs the RPMS necessary to create system ("root + resource") slices from the virtual server (VServer) reference image. + %prep %setup -q %build +pushd vserver-reference +./build.sh -r 2 +# Not until we can get the build server to run Fedora Core 4 or an +# updated version of yum. +#./build.sh -r 4 +./system-packages.sh +popd %install rm -rf $RPM_BUILD_ROOT -install -D -m 755 %{name}.init $RPM_BUILD_ROOT/%{_initrddir}/%{name} + +pushd vserver-reference +install -D -m 755 vserver-reference.init $RPM_BUILD_ROOT/%{_initrddir}/vserver-reference +find vservers | cpio -p -d -u $RPM_BUILD_ROOT/ +popd %clean rm -rf $RPM_BUILD_ROOT -%files +# If run under sudo +if [ -n "$SUDO_USER" ] ; then + # Allow user to delete the build directory + chown -R $SUDO_USER . + # Some temporary cdroot files like /var/empty/sshd and + # /usr/bin/sudo get created with non-readable permissions. + find . -not -perm +0600 -exec chmod u+rw {} \; + # Allow user to delete the built RPM(s) + chown -R $SUDO_USER %{_rpmdir}/%{_arch} +fi + +%files reference +%defattr(-,root,root) +%{_initrddir}/vserver-reference +/vservers/vserver-reference + +%files system-packages %defattr(-,root,root) -%{_initrddir}/%{name} +/vservers/system-packages + +%define vcached_pid /var/run/vcached.pid -%post -chkconfig --add %{name} -chkconfig %{name} on +%pre reference +# Stop vcached +if [ -r %{vcached_pid} ] ; then + kill $(cat %{vcached_pid}) +fi +echo $$ > %{vcached_pid} + +# vcached will clean up .vtmp later +mkdir -p /vservers/.vtmp +if [ -d /vservers/vserver-reference ] ; then + mv /vservers/vserver-reference /vservers/.vtmp/vserver-reference.$RANDOM +fi +if [ -d /vservers/.vcache ] ; then + mv /vservers/.vcache /vservers/.vtmp/.vcache.$RANDOM +fi + +# Allow vcached to run again +rm -f %{vcached_pid} + +%post reference +chkconfig --add vserver-reference +chkconfig vserver-reference on +[ "$PL_BOOTCD" = "1" ] || service vserver-reference start %changelog +* Tue Sep 1 2005 Mark Huang 3.1-1.planetlab +- Pre-package vserver-reference instead of building it on nodes + * Tue Nov 30 2004 Mark Huang 3.0-5.planetlab - PL3118 and PL3131 fix: set barrier bit on /vservers instead of old immulink bit. Do not reset the immutable bit on the new