| #!/bin/bash |
| |
| if [ ! "$#" -eq "1" ]; then |
| echo "$0 builds a gziped natty openstack install" |
| echo "usage: $0 dest" |
| exit 1 |
| fi |
| |
| PROGDIR=`dirname $0` |
| |
| # Source params |
| source ./stackrc |
| |
| # clean install of natty |
| if [ ! -d natty-base ]; then |
| $PROGDIR/make_image.sh -C natty natty-base |
| # copy kernel modules... |
| # NOTE(ja): is there a better way to do this? |
| cp -pr /lib/modules/`uname -r` natty-base/lib/modules |
| # a simple password - pass |
| echo root:pass | chroot natty-base chpasswd |
| fi |
| |
| # prime natty with as many apt/pips as we can |
| if [ ! -d primed ]; then |
| rsync -azH natty-base/ primed/ |
| chroot primed apt-get install -y `cat files/apts/* | cut -d\# -f1 | egrep -v "(rabbitmq|libvirt-bin|mysql-server)"` |
| chroot primed 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 primed groupadd libvirtd |
| chroot primed useradd stack -s /bin/bash -d /opt -G libvirtd |
| |
| # a simple password - pass |
| echo stack:pass | chroot primed chpasswd |
| |
| # and has sudo ability (in the future this should be limited to only what |
| # stack requires) |
| echo "stack ALL=(ALL) NOPASSWD: ALL" >> primed/etc/sudoers |
| fi |
| |
| # clone git repositories onto the system |
| # ====================================== |
| |
| if [ ! -d cloned ]; then |
| rsync -azH primed/ cloned/ |
| 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=cloned$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 cloned/ chown -R stack $2 |
| } |
| |
| git_clone $NOVA_REPO /opt/stack/nova $NOVA_BRANCH |
| git_clone $GLANCE_REPO /opt/stack/glance $GLANCE_BRANCH |
| git_clone $KEYSTONE_REPO /opt/stack/keystone $KEYSTONE_BRANCH |
| git_clone $NOVNC_REPO /opt/stack/novnc $NOVNC_BRANCH |
| git_clone $DASH_REPO /opt/stack/dash $DASH_BRANCH |
| git_clone $NIXON_REPO /opt/stack/nixon $NIXON_BRANCH |
| git_clone $NOVACLIENT_REPO /opt/stack/python-novaclient $NOVACLIENT_BRANCH |
| git_clone $OPENSTACKX_REPO /opt/stack/openstackx $OPENSTACKX_BRANCH |
| git_clone $MUNIN_REPO /opt/stack/openstack-munin $MUNIN_BRANCH |
| |
| # build a new image |
| BASE=build.$$ |
| IMG=$BASE.img |
| MNT=$BASE/ |
| |
| # (quickly) create a 2GB blank filesystem |
| dd bs=1 count=1 seek=$((2*1024*1024*1024)) if=/dev/zero of=$IMG |
| # force it to be initialized as ext2 |
| mkfs.ext2 -F $IMG |
| |
| # mount blank image loopback and load it |
| mkdir -p $MNT |
| mount -o loop $IMG $MNT |
| rsync -azH cloned/ $MNT |
| |
| # umount and cleanup |
| umount $MNT |
| rmdir $MNT |
| |
| # gzip into final location |
| gzip -1 $IMG -c > $1 |
| |