| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 1 | #!/bin/bash | 
 | 2 |  | 
 | 3 | # Abort if localrc is not set | 
 | 4 | if [ ! -e ../../localrc ]; then | 
 | 5 |     echo "You must have a localrc with ALL necessary passwords defined before proceeding." | 
 | 6 |     echo "See the xen README for required passwords." | 
 | 7 |     exit 1 | 
 | 8 | fi | 
 | 9 |  | 
| Anthony Young | af6ed6b | 2011-11-02 07:50:27 -0500 | [diff] [blame] | 10 | # This directory | 
 | 11 | TOP_DIR=$(cd $(dirname "$0") && pwd) | 
 | 12 |  | 
 | 13 | # Source params | 
 | 14 | cd ../.. && source ./stackrc && cd $TOP_DIR | 
 | 15 |  | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 16 | # Echo commands | 
 | 17 | set -o xtrace | 
 | 18 |  | 
 | 19 | # Name of this guest | 
 | 20 | GUEST_NAME=${GUEST_NAME:-ALLINONE} | 
 | 21 |  | 
 | 22 | # dom0 ip | 
 | 23 | HOST_IP=${HOST_IP:-`ifconfig xenbr0 | grep "inet addr" | cut -d ":" -f2 | sed "s/ .*//"`} | 
 | 24 |  | 
 | 25 | # Our nova host's network info  | 
| Anthony Young | f6ef569 | 2011-10-26 23:40:46 -0700 | [diff] [blame] | 26 | VM_IP=${VM_IP:-10.255.255.255} # A host-only ip that let's the interface come up, otherwise unused | 
 | 27 | MGT_IP=${MGT_IP:-172.16.100.55} | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 28 | PUB_IP=${PUB_IP:-192.168.1.55} | 
 | 29 |  | 
 | 30 | # Public network | 
 | 31 | PUB_BR=${PUB_BR:-xenbr0} | 
 | 32 | PUB_NETMASK=${PUB_NETMASK:-255.255.255.0} | 
 | 33 |  | 
 | 34 | # VM network params | 
 | 35 | VM_NETMASK=${VM_NETMASK:-255.255.255.0} | 
| Anthony Young | 419770f | 2012-01-11 17:35:40 -0800 | [diff] [blame] | 36 | VM_BR=${VM_BR:-xapi1} | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 37 | VM_VLAN=${VM_VLAN:-100} | 
 | 38 |  | 
 | 39 | # MGMT network params | 
 | 40 | MGT_NETMASK=${MGT_NETMASK:-255.255.255.0} | 
| Anthony Young | 419770f | 2012-01-11 17:35:40 -0800 | [diff] [blame] | 41 | MGT_BR=${MGT_BR:-xapi2} | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 42 | MGT_VLAN=${MGT_VLAN:-101} | 
 | 43 |  | 
 | 44 | # VM Password | 
| Anthony Young | a693655 | 2011-10-26 23:29:59 -0700 | [diff] [blame] | 45 | GUEST_PASSWORD=${GUEST_PASSWORD:-secrete} | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 46 |  | 
 | 47 | # Size of image | 
 | 48 | VDI_MB=${VDI_MB:-2500} | 
 | 49 |  | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 50 | # Make sure we have git | 
 | 51 | if ! which git; then | 
 | 52 |     GITDIR=/tmp/git-1.7.7 | 
 | 53 |     cd /tmp | 
 | 54 |     rm -rf $GITDIR* | 
 | 55 |     wget http://git-core.googlecode.com/files/git-1.7.7.tar.gz | 
 | 56 |     tar xfv git-1.7.7.tar.gz | 
 | 57 |     cd $GITDIR | 
 | 58 |     ./configure | 
 | 59 |     make install | 
 | 60 |     cd $TOP_DIR | 
 | 61 | fi | 
 | 62 |  | 
 | 63 | # Helper to create networks | 
 | 64 | function create_network() { | 
 | 65 |     if ! xe network-list | grep bridge | grep -q $1; then | 
 | 66 |         echo "Creating bridge $1" | 
 | 67 |         xe network-create name-label=$1 | 
 | 68 |     fi | 
 | 69 | } | 
 | 70 |  | 
 | 71 | # Create host, vm, mgmt, pub networks | 
 | 72 | create_network xapi0 | 
 | 73 | create_network $VM_BR | 
 | 74 | create_network $MGT_BR | 
 | 75 | create_network $PUB_BR | 
 | 76 |  | 
 | 77 | # Get the uuid for our physical (public) interface | 
 | 78 | PIF=`xe pif-list --minimal device=eth0` | 
 | 79 |  | 
 | 80 | # Create networks/bridges for vm and management | 
 | 81 | VM_NET=`xe network-list --minimal bridge=$VM_BR` | 
 | 82 | MGT_NET=`xe network-list --minimal bridge=$MGT_BR` | 
 | 83 |  | 
 | 84 | # Helper to create vlans | 
 | 85 | function create_vlan() { | 
 | 86 |     pif=$1 | 
 | 87 |     vlan=$2 | 
 | 88 |     net=$3 | 
 | 89 |     if ! xe vlan-list | grep tag | grep -q $vlan; then | 
 | 90 |         xe vlan-create pif-uuid=$pif vlan=$vlan network-uuid=$net | 
 | 91 |     fi | 
 | 92 | } | 
 | 93 |  | 
 | 94 | # Create vlans for vm and management | 
 | 95 | create_vlan $PIF $VM_VLAN $VM_NET | 
 | 96 | create_vlan $PIF $MGT_VLAN $MGT_NET | 
 | 97 |  | 
 | 98 | # Setup host-only nat rules | 
 | 99 | HOST_NET=169.254.0.0/16 | 
 | 100 | if ! iptables -L -v -t nat | grep -q $HOST_NET; then | 
 | 101 |     iptables -t nat -A POSTROUTING -s $HOST_NET -j SNAT --to-source $HOST_IP | 
 | 102 |     iptables -I FORWARD 1 -s $HOST_NET -j ACCEPT | 
 | 103 |     /etc/init.d/iptables save | 
 | 104 | fi | 
 | 105 |  | 
 | 106 | # Set up ip forwarding | 
 | 107 | if ! grep -q "FORWARD_IPV4=YES" /etc/sysconfig/network; then | 
 | 108 |     # FIXME: This doesn't work on reboot! | 
 | 109 |     echo "FORWARD_IPV4=YES" >> /etc/sysconfig/network | 
 | 110 | fi | 
 | 111 |  | 
 | 112 | # Also, enable ip forwarding in rc.local, since the above trick isn't working | 
 | 113 | if ! grep -q  "echo 1 >/proc/sys/net/ipv4/ip_forward" /etc/rc.local; then | 
 | 114 |     echo "echo 1 >/proc/sys/net/ipv4/ip_forward" >> /etc/rc.local | 
 | 115 | fi | 
 | 116 |  | 
 | 117 | # Enable ip forwarding at runtime as well | 
 | 118 | echo 1 > /proc/sys/net/ipv4/ip_forward | 
 | 119 |  | 
 | 120 | # Directory where we stage the build | 
 | 121 | STAGING_DIR=$TOP_DIR/stage | 
 | 122 |  | 
 | 123 | # Option to clean out old stuff | 
 | 124 | CLEAN=${CLEAN:-0} | 
 | 125 | if [ "$CLEAN" = "1" ]; then | 
 | 126 |     rm -rf $STAGING_DIR | 
 | 127 | fi | 
 | 128 |  | 
 | 129 | # Download our base image.  This image is made using prepare_guest.sh | 
 | 130 | BASE_IMAGE_URL=${BASE_IMAGE_URL:-http://images.ansolabs.com/xen/stage.tgz} | 
 | 131 | if [ ! -e $STAGING_DIR ]; then | 
 | 132 |     if [ ! -e /tmp/stage.tgz ]; then | 
 | 133 |         wget $BASE_IMAGE_URL -O /tmp/stage.tgz | 
 | 134 |     fi | 
 | 135 |     tar xfz /tmp/stage.tgz | 
 | 136 |     cd $TOP_DIR | 
 | 137 | fi | 
 | 138 |  | 
 | 139 | # Free up precious disk space | 
 | 140 | rm -f /tmp/stage.tgz | 
 | 141 |  | 
 | 142 | # Make sure we have a stage | 
 | 143 | if [ ! -d $STAGING_DIR/etc ]; then | 
 | 144 |     echo "Stage is not properly set up!" | 
 | 145 |     exit 1 | 
 | 146 | fi | 
 | 147 |  | 
 | 148 | # Directory where our conf files are stored | 
 | 149 | FILES_DIR=$TOP_DIR/files | 
| Anthony Young | 3eb8f59 | 2011-10-26 23:11:52 -0700 | [diff] [blame] | 150 | TEMPLATES_DIR=$TOP_DIR/templates | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 151 |  | 
 | 152 | # Directory for supporting script files | 
 | 153 | SCRIPT_DIR=$TOP_DIR/scripts | 
 | 154 |  | 
 | 155 | # Version of ubuntu with which we are working | 
 | 156 | UBUNTU_VERSION=`cat $STAGING_DIR/etc/lsb-release | grep "DISTRIB_CODENAME=" | sed "s/DISTRIB_CODENAME=//"` | 
 | 157 | KERNEL_VERSION=`ls $STAGING_DIR/boot/vmlinuz* | head -1 | sed "s/.*vmlinuz-//"` | 
 | 158 |  | 
 | 159 | # Setup fake grub | 
 | 160 | rm -rf $STAGING_DIR/boot/grub/ | 
 | 161 | mkdir -p $STAGING_DIR/boot/grub/ | 
| Anthony Young | 3eb8f59 | 2011-10-26 23:11:52 -0700 | [diff] [blame] | 162 | cp $TEMPLATES_DIR/menu.lst.in $STAGING_DIR/boot/grub/menu.lst | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 163 | sed -e "s,@KERNEL_VERSION@,$KERNEL_VERSION,g" -i $STAGING_DIR/boot/grub/menu.lst | 
 | 164 |  | 
 | 165 | # Setup fstab, tty, and other system stuff | 
 | 166 | cp $FILES_DIR/fstab $STAGING_DIR/etc/fstab | 
 | 167 | cp $FILES_DIR/hvc0.conf $STAGING_DIR/etc/init/ | 
 | 168 |  | 
 | 169 | # Put the VPX into UTC. | 
 | 170 | rm -f $STAGING_DIR/etc/localtime | 
 | 171 |  | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 172 | # Configure dns (use same dns as dom0) | 
 | 173 | cp /etc/resolv.conf $STAGING_DIR/etc/resolv.conf | 
 | 174 |  | 
 | 175 | # Copy over devstack | 
 | 176 | rm -f /tmp/devstack.tar | 
 | 177 | tar --exclude='stage' --exclude='xen/xvas' --exclude='xen/nova' -cvf /tmp/devstack.tar $TOP_DIR/../../../devstack | 
 | 178 | cd $STAGING_DIR/opt/stack/ | 
 | 179 | tar xf /tmp/devstack.tar | 
 | 180 | cd $TOP_DIR | 
 | 181 |  | 
 | 182 | # Configure OVA | 
 | 183 | VDI_SIZE=$(($VDI_MB*1024*1024)) | 
 | 184 | PRODUCT_BRAND=${PRODUCT_BRAND:-openstack} | 
 | 185 | PRODUCT_VERSION=${PRODUCT_VERSION:-001} | 
 | 186 | BUILD_NUMBER=${BUILD_NUMBER:-001} | 
 | 187 | LABEL="$PRODUCT_BRAND $PRODUCT_VERSION-$BUILD_NUMBER" | 
 | 188 | OVA=$STAGING_DIR/tmp/ova.xml | 
| Anthony Young | 3eb8f59 | 2011-10-26 23:11:52 -0700 | [diff] [blame] | 189 | cp $TEMPLATES_DIR/ova.xml.in  $OVA | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 190 | sed -e "s,@VDI_SIZE@,$VDI_SIZE,g" -i $OVA | 
 | 191 | sed -e "s,@PRODUCT_BRAND@,$PRODUCT_BRAND,g" -i $OVA | 
 | 192 | sed -e "s,@PRODUCT_VERSION@,$PRODUCT_VERSION,g" -i $OVA | 
 | 193 | sed -e "s,@BUILD_NUMBER@,$BUILD_NUMBER,g" -i $OVA | 
 | 194 |  | 
 | 195 | # Directory for xvas | 
 | 196 | XVA_DIR=$TOP_DIR/xvas | 
 | 197 |  | 
 | 198 | # Create xva dir | 
 | 199 | mkdir -p $XVA_DIR | 
 | 200 |  | 
 | 201 | # Clean nova if desired | 
 | 202 | if [ "$CLEAN" = "1" ]; then | 
 | 203 |     rm -rf $TOP_DIR/nova | 
 | 204 | fi | 
 | 205 |  | 
 | 206 | # Checkout nova | 
 | 207 | if [ ! -d $TOP_DIR/nova ]; then | 
| Anthony Young | 419770f | 2012-01-11 17:35:40 -0800 | [diff] [blame] | 208 |     git clone $NOVA_REPO | 
 | 209 |     cd $TOP_DIR/nova | 
 | 210 |     git checkout $NOVA_BRANCH | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 211 | fi  | 
 | 212 |  | 
 | 213 | # Run devstack on launch | 
 | 214 | cat <<EOF >$STAGING_DIR/etc/rc.local | 
| Anthony Young | f54bc06 | 2011-10-27 00:39:30 -0700 | [diff] [blame] | 215 | GUEST_PASSWORD=$GUEST_PASSWORD STAGING_DIR=/ DO_TGZ=0 bash /opt/stack/devstack/tools/xen/prepare_guest.sh | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 216 | su -c "/opt/stack/run.sh > /opt/stack/run.sh.log" stack | 
 | 217 | exit 0 | 
 | 218 | EOF | 
 | 219 |  | 
 | 220 | # Install plugins | 
 | 221 | cp -pr $TOP_DIR/nova/plugins/xenserver/xenapi/etc/xapi.d /etc/ | 
 | 222 | chmod a+x /etc/xapi.d/plugins/* | 
 | 223 | yum --enablerepo=base install -y parted | 
 | 224 | mkdir -p /boot/guest | 
 | 225 |  | 
 | 226 | # Set local storage il8n | 
 | 227 | SR_UUID=`xe sr-list --minimal name-label="Local storage"` | 
 | 228 | xe sr-param-set uuid=$SR_UUID other-config:i18n-key=local-storage | 
 | 229 |  | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 230 |  | 
| Anthony Young | 346e491 | 2011-11-05 00:22:47 -0500 | [diff] [blame] | 231 | # Shutdown previous runs | 
 | 232 | DO_SHUTDOWN=${DO_SHUTDOWN:-1} | 
 | 233 | if [ "$DO_SHUTDOWN" = "1" ]; then | 
| Anthony Young | 40b5737 | 2011-11-05 00:30:07 -0500 | [diff] [blame] | 234 |     # Shutdown all domU's that created previously | 
| Anthony Young | 346e491 | 2011-11-05 00:22:47 -0500 | [diff] [blame] | 235 |     xe vm-list --minimal name-label="$LABEL" | xargs ./scripts/uninstall-os-vpx.sh | 
 | 236 |  | 
 | 237 |     # Destroy any instances that were launched | 
 | 238 |     for uuid in `xe vm-list | grep -1 instance | grep uuid | sed "s/.*\: //g"`; do | 
 | 239 |         echo "Shutting down nova instance $uuid" | 
 | 240 |         xe vm-unpause uuid=$uuid || true | 
 | 241 |         xe vm-shutdown uuid=$uuid | 
 | 242 |         xe vm-destroy uuid=$uuid | 
 | 243 |     done | 
| Anthony Young | fa4ecc6 | 2011-11-11 10:23:22 -0800 | [diff] [blame] | 244 |  | 
 | 245 |     # Destroy orphaned vdis | 
 | 246 |     for uuid in `xe vdi-list | grep -1 Glance | grep uuid | sed "s/.*\: //g"`; do | 
 | 247 |         xe vdi-destroy uuid=$uuid | 
 | 248 |     done | 
| Anthony Young | 346e491 | 2011-11-05 00:22:47 -0500 | [diff] [blame] | 249 | fi | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 250 |  | 
 | 251 | # Path to head xva.  By default keep overwriting the same one to save space | 
 | 252 | USE_SEPARATE_XVAS=${USE_SEPARATE_XVAS:-0} | 
 | 253 | if [ "$USE_SEPARATE_XVAS" = "0" ]; then | 
 | 254 |     XVA=$XVA_DIR/$UBUNTU_VERSION.xva  | 
 | 255 | else | 
 | 256 |     XVA=$XVA_DIR/$UBUNTU_VERSION.$GUEST_NAME.xva  | 
 | 257 | fi | 
 | 258 |  | 
 | 259 | # Clean old xva. In the future may not do this every time. | 
 | 260 | rm -f $XVA | 
 | 261 |  | 
| Anthony Young | 138b283 | 2011-10-27 13:06:39 -0700 | [diff] [blame] | 262 | # Configure the hostname | 
 | 263 | echo $GUEST_NAME > $STAGING_DIR/etc/hostname | 
 | 264 |  | 
 | 265 | # Hostname must resolve for rabbit | 
 | 266 | cat <<EOF >$STAGING_DIR/etc/hosts | 
 | 267 | $MGT_IP $GUEST_NAME | 
 | 268 | 127.0.0.1 localhost localhost.localdomain | 
 | 269 | EOF | 
 | 270 |  | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 271 | # Configure the network | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 272 | INTERFACES=$STAGING_DIR/etc/network/interfaces | 
| Anthony Young | 3eb8f59 | 2011-10-26 23:11:52 -0700 | [diff] [blame] | 273 | cp $TEMPLATES_DIR/interfaces.in  $INTERFACES | 
| Anthony Young | f6ef569 | 2011-10-26 23:40:46 -0700 | [diff] [blame] | 274 | sed -e "s,@ETH1_IP@,$VM_IP,g" -i $INTERFACES | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 275 | sed -e "s,@ETH1_NETMASK@,$VM_NETMASK,g" -i $INTERFACES | 
 | 276 | sed -e "s,@ETH2_IP@,$MGT_IP,g" -i $INTERFACES | 
 | 277 | sed -e "s,@ETH2_NETMASK@,$MGT_NETMASK,g" -i $INTERFACES | 
 | 278 | sed -e "s,@ETH3_IP@,$PUB_IP,g" -i $INTERFACES | 
 | 279 | sed -e "s,@ETH3_NETMASK@,$PUB_NETMASK,g" -i $INTERFACES | 
 | 280 |  | 
| Anthony Young | a1a9077 | 2011-10-31 15:32:38 -0700 | [diff] [blame] | 281 | # Gracefully cp only if source file/dir exists | 
 | 282 | function cp_it { | 
 | 283 |     if [ -e $1 ] || [ -d $1 ]; then | 
 | 284 |         cp -pRL $1 $2 | 
 | 285 |     fi | 
 | 286 | } | 
 | 287 |  | 
 | 288 | # Copy over your ssh keys and env if desired | 
 | 289 | COPYENV=${COPYENV:-1} | 
 | 290 | if [ "$COPYENV" = "1" ]; then | 
 | 291 |     cp_it ~/.ssh $STAGING_DIR/opt/stack/.ssh | 
 | 292 |     cp_it ~/.ssh/id_rsa.pub $STAGING_DIR/opt/stack/.ssh/authorized_keys | 
 | 293 |     cp_it ~/.gitconfig $STAGING_DIR/opt/stack/.gitconfig | 
 | 294 |     cp_it ~/.vimrc $STAGING_DIR/opt/stack/.vimrc | 
 | 295 |     cp_it ~/.bashrc $STAGING_DIR/opt/stack/.bashrc | 
 | 296 | fi | 
 | 297 |  | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 298 | # Configure run.sh | 
 | 299 | cat <<EOF >$STAGING_DIR/opt/stack/run.sh | 
 | 300 | #!/bin/bash | 
 | 301 | cd /opt/stack/devstack | 
 | 302 | killall screen | 
 | 303 | UPLOAD_LEGACY_TTY=yes HOST_IP=$PUB_IP VIRT_DRIVER=xenserver FORCE=yes MULTI_HOST=1 $STACKSH_PARAMS ./stack.sh | 
 | 304 | EOF | 
 | 305 | chmod 755 $STAGING_DIR/opt/stack/run.sh | 
 | 306 |  | 
 | 307 | # Create xva | 
 | 308 | if [ ! -e $XVA ]; then | 
 | 309 |     rm -rf /tmp/mkxva* | 
 | 310 |     UID=0 $SCRIPT_DIR/mkxva -o $XVA -t xva -x $OVA $STAGING_DIR $VDI_MB /tmp/ | 
 | 311 | fi | 
 | 312 |  | 
 | 313 | # Start guest | 
 | 314 | $TOP_DIR/scripts/install-os-vpx.sh -f $XVA -v $VM_BR -m $MGT_BR -p $PUB_BR | 
| Anthony Young | 3eb8f59 | 2011-10-26 23:11:52 -0700 | [diff] [blame] | 315 |  | 
| Anthony Young | 1de18c6 | 2011-11-01 14:19:18 -0500 | [diff] [blame] | 316 | # If we have copied our ssh credentials, use ssh to monitor while the installation runs | 
 | 317 | WAIT_TILL_LAUNCH=${WAIT_TILL_LAUNCH:-1} | 
 | 318 | if [ "$WAIT_TILL_LAUNCH" = "1" ]  && [ -e ~/.ssh/id_rsa.pub  ] && [ "$COPYENV" = "1" ]; then | 
 | 319 |     # Done creating the container, let's tail the log | 
 | 320 |     echo | 
 | 321 |     echo "=============================================================" | 
 | 322 |     echo "                          -- YAY! --" | 
 | 323 |     echo "=============================================================" | 
 | 324 |     echo | 
 | 325 |     echo "We're done launching the vm, about to start tailing the" | 
 | 326 |     echo "stack.sh log. It will take a second or two to start." | 
 | 327 |     echo | 
 | 328 |     echo "Just CTRL-C at any time to stop tailing." | 
 | 329 |  | 
 | 330 |     set +o xtrace | 
 | 331 |  | 
 | 332 |     while ! ssh -q stack@$PUB_IP "[ -e run.sh.log ]"; do | 
 | 333 |       sleep 1 | 
 | 334 |     done | 
 | 335 |  | 
 | 336 |     ssh stack@$PUB_IP 'tail -f run.sh.log' & | 
 | 337 |  | 
 | 338 |     TAIL_PID=$! | 
 | 339 |  | 
 | 340 |     function kill_tail() { | 
 | 341 |         kill $TAIL_PID | 
 | 342 |         exit 1 | 
 | 343 |     } | 
 | 344 |  | 
 | 345 |     # Let Ctrl-c kill tail and exit | 
 | 346 |     trap kill_tail SIGINT | 
 | 347 |  | 
 | 348 |     echo "Waiting stack.sh to finish..." | 
| Anthony Young | f0dca55 | 2011-11-01 14:23:14 -0700 | [diff] [blame] | 349 |     while ! ssh -q stack@$PUB_IP "grep -q 'stack.sh completed in' run.sh.log"; do | 
| Anthony Young | 1de18c6 | 2011-11-01 14:19:18 -0500 | [diff] [blame] | 350 |         sleep 1 | 
 | 351 |     done | 
 | 352 |  | 
 | 353 |     kill $TAIL_PID | 
 | 354 |  | 
| Anthony Young | f0dca55 | 2011-11-01 14:23:14 -0700 | [diff] [blame] | 355 |     if ssh -q stack@$PUB_IP "grep -q 'stack.sh failed' run.sh.log"; then | 
| Anthony Young | 1de18c6 | 2011-11-01 14:19:18 -0500 | [diff] [blame] | 356 |         exit 1 | 
 | 357 |     fi | 
 | 358 |     echo "" | 
 | 359 |     echo "Finished - Zip-a-dee Doo-dah!" | 
 | 360 |     echo "You can then visit the OpenStack Dashboard" | 
 | 361 |     echo "at http://$PUB_IP, and contact other services at the usual ports." | 
 | 362 | else | 
 | 363 |     echo "################################################################################" | 
 | 364 |     echo "" | 
 | 365 |     echo "All Finished!" | 
 | 366 |     echo "Now, you can monitor the progress of the stack.sh installation by " | 
 | 367 |     echo "tailing /opt/stack/run.sh.log from within your domU." | 
 | 368 |     echo "" | 
 | 369 |     echo "ssh into your domU now: 'ssh stack@$PUB_IP' using your password" | 
 | 370 |     echo "and then do: 'tail -f /opt/stack/run.sh.log'" | 
 | 371 |     echo "" | 
 | 372 |     echo "When the script completes, you can then visit the OpenStack Dashboard" | 
 | 373 |     echo "at http://$PUB_IP, and contact other services at the usual ports." | 
 | 374 |  | 
 | 375 | fi |