| #!/bin/bash |
| |
| PROGDIR=`dirname $0` |
| CHROOTCACHE=${CHROOTCACHE:-/var/cache/devstack} |
| |
| # Source params |
| source ./stackrc |
| |
| # Store cwd |
| CWD=`pwd` |
| |
| NAME=$1 |
| NFSDIR="/nfs/$NAME" |
| DEST=${DEST:-/opt/stack} |
| |
| # Option to use the version of devstack on which we are currently working |
| USE_CURRENT_DEVSTACK=${USE_CURRENT_DEVSTACK:-1} |
| |
| # remove old nfs filesystem if one exists |
| rm -rf $DEST |
| |
| # clean install of natty |
| if [ ! -d $CHROOTCACHE/natty-base ]; then |
| $PROGDIR/make_image.sh -C natty $CHROOTCACHE/natty-base |
| # copy kernel modules... |
| # NOTE(ja): is there a better way to do this? |
| cp -pr /lib/modules/`uname -r` $CHROOTCACHE/natty-base/lib/modules |
| # a simple password - pass |
| echo root:pass | chroot $CHROOTCACHE/natty-base chpasswd |
| fi |
| |
| # prime natty with as many apt/pips as we can |
| if [ ! -d $CHROOTCACHE/natty-dev ]; then |
| rsync -azH $CHROOTCACHE/natty-base/ $CHROOTCACHE/natty-dev/ |
| chroot $CHROOTCACHE/natty-dev apt-get install -y `cat files/apts/* | cut -d\# -f1 | egrep -v "(rabbitmq|libvirt-bin|mysql-server)"` |
| chroot $CHROOTCACHE/natty-dev pip install `cat files/pips/*` |
| |
| # Create a stack user that is a member of the libvirtd group so that stack |
| # is able to interact with libvirt. |
| chroot $CHROOTCACHE/natty-dev groupadd libvirtd |
| chroot $CHROOTCACHE/natty-dev useradd stack -s /bin/bash -d $DEST -G libvirtd |
| mkdir -p $CHROOTCACHE/natty-dev/$DEST |
| chown stack $CHROOTCACHE/natty-dev/$DEST |
| |
| # a simple password - pass |
| echo stack:pass | chroot $CHROOTCACHE/natty-dev chpasswd |
| |
| # and has sudo ability (in the future this should be limited to only what |
| # stack requires) |
| echo "stack ALL=(ALL) NOPASSWD: ALL" >> $CHROOTCACHE/natty-dev/etc/sudoers |
| fi |
| |
| # clone git repositories onto the system |
| # ====================================== |
| |
| if [ ! -d $CHROOTCACHE/natty-stack ]; then |
| rsync -azH $CHROOTCACHE/natty-dev/ $CHROOTCACHE/natty-stack/ |
| fi |
| |
| # git clone only if directory doesn't exist already. Since ``DEST`` might not |
| # be owned by the installation user, we create the directory and change the |
| # ownership to the proper user. |
| function git_clone { |
| |
| # clone new copy or fetch latest changes |
| CHECKOUT=$CHROOTCACHE/natty-stack$2 |
| if [ ! -d $CHECKOUT ]; then |
| mkdir -p $CHECKOUT |
| git clone $1 $CHECKOUT |
| else |
| pushd $CHECKOUT |
| git fetch |
| popd |
| fi |
| |
| # FIXME(ja): checkout specified version (should works for branches and tags) |
| |
| pushd $CHECKOUT |
| # checkout the proper branch/tag |
| git checkout $3 |
| # force our local version to be the same as the remote version |
| git reset --hard origin/$3 |
| popd |
| |
| # give ownership to the stack user |
| chroot $CHROOTCACHE/natty-stack/ chown -R stack $2 |
| } |
| |
| git_clone $NOVA_REPO $DEST/nova $NOVA_BRANCH |
| git_clone $GLANCE_REPO $DEST/glance $GLANCE_BRANCH |
| git_clone $KEYSTONE_REPO $DEST/keystone $KEYSTONE_BRANCH |
| git_clone $NOVNC_REPO $DEST/novnc $NOVNC_BRANCH |
| git_clone $DASH_REPO $DEST/dash $DASH_BRANCH $DASH_TAG |
| git_clone $NOVACLIENT_REPO $DEST/python-novaclient $NOVACLIENT_BRANCH |
| git_clone $OPENSTACKX_REPO $DEST/openstackx $OPENSTACKX_BRANCH |
| |
| chroot $CHROOTCACHE/natty-stack mkdir -p $DEST/files |
| wget -c http://images.ansolabs.com/tty.tgz -O $CHROOTCACHE/natty-stack$DEST/files/tty.tgz |
| |
| # Use this version of devstack? |
| if [ "$USE_CURRENT_DEVSTACK" = "1" ]; then |
| rm -rf $CHROOTCACHE/natty-stack/$DEST/devstack |
| cp -pr $CWD $CHROOTCACHE/natty-stack/$DEST/devstack |
| fi |
| |
| cp -pr $CHROOTCACHE/natty-stack $NFSDIR |
| |
| # set hostname |
| echo $NAME > $NFSDIR/etc/hostname |
| echo "127.0.0.1 localhost $NAME" > $NFSDIR/etc/hosts |
| |
| # injecting root's public ssh key if it exists |
| if [ -f /root/.ssh/id_rsa.pub ]; then |
| mkdir $NFSDIR/root/.ssh |
| chmod 700 $NFSDIR/root/.ssh |
| cp /root/.ssh/id_rsa.pub $NFSDIR/root/.ssh/authorized_keys |
| fi |