| #!/bin/bash |
| |
| # This script is run by install_os_domU.sh |
| # |
| # It modifies the ubuntu image created by install_os_domU.sh |
| # and previously moodified by prepare_guest_template.sh |
| # |
| # This script is responsible for: |
| # - pushing in the DevStack code |
| # - creating run.sh, to run the code on boot |
| # It does this by mounting the disk image of the VM. |
| # |
| # The resultant image is then templated and started |
| # by install_os_domU.sh |
| |
| # Exit on errors |
| set -o errexit |
| # Echo commands |
| set -o xtrace |
| |
| # This directory |
| TOP_DIR=$(cd $(dirname "$0") && pwd) |
| |
| # Include onexit commands |
| . $TOP_DIR/scripts/on_exit.sh |
| |
| # xapi functions |
| . $TOP_DIR/functions |
| |
| # Source params - override xenrc params in your localrc to suite your taste |
| source xenrc |
| |
| # |
| # Parameters |
| # |
| GUEST_NAME="$1" |
| |
| function _print_interface_config { |
| local device_nr |
| local ip_address |
| local netmask |
| |
| device_nr="$1" |
| ip_address="$2" |
| netmask="$3" |
| |
| local device |
| |
| device="eth${device_nr}" |
| |
| echo "auto $device" |
| if [ $ip_address == "dhcp" ]; then |
| echo "iface $device inet dhcp" |
| else |
| echo "iface $device inet static" |
| echo " address $ip_address" |
| echo " netmask $netmask" |
| fi |
| |
| # Turn off tx checksumming for better performance |
| echo " post-up ethtool -K $device tx off" |
| } |
| |
| function print_interfaces_config { |
| echo "auto lo" |
| echo "iface lo inet loopback" |
| |
| _print_interface_config $PUB_DEV_NR $PUB_IP $PUB_NETMASK |
| _print_interface_config $VM_DEV_NR $VM_IP $VM_NETMASK |
| _print_interface_config $MGT_DEV_NR $MGT_IP $MGT_NETMASK |
| } |
| |
| # |
| # Mount the VDI |
| # |
| STAGING_DIR=$($TOP_DIR/scripts/manage-vdi open $GUEST_NAME 0 1 | grep -o "/tmp/tmp.[[:alnum:]]*") |
| add_on_exit "$TOP_DIR/scripts/manage-vdi close $GUEST_NAME 0 1" |
| |
| # Make sure we have a stage |
| if [ ! -d $STAGING_DIR/etc ]; then |
| echo "Stage is not properly set up!" |
| exit 1 |
| fi |
| |
| # Only support DHCP for now - don't support how different versions of Ubuntu handle resolv.conf |
| if [ "$MGT_IP" != "dhcp" ] && [ "$PUB_IP" != "dhcp" ]; then |
| echo "Configuration without DHCP not supported" |
| exit 1 |
| fi |
| |
| # Copy over devstack |
| rm -f /tmp/devstack.tar |
| cd $TOP_DIR/../../ |
| tar --exclude='stage' --exclude='xen/xvas' --exclude='xen/nova' -cvf /tmp/devstack.tar . |
| mkdir -p $STAGING_DIR/opt/stack/devstack |
| tar xf /tmp/devstack.tar -C $STAGING_DIR/opt/stack/devstack |
| cd $TOP_DIR |
| |
| # Create an upstart job (task) for devstack, which can interact with the console |
| cat >$STAGING_DIR/etc/init/devstack.conf << EOF |
| start on stopped rc RUNLEVEL=[2345] |
| |
| console output |
| task |
| |
| pre-start script |
| rm -f /opt/stack/runsh.succeeded |
| end script |
| |
| script |
| initctl stop hvc0 || true |
| |
| # Read any leftover characters from standard input |
| while read -n 1 -s -t 0.1 -r ignored; do |
| true |
| done |
| |
| clear |
| |
| chown -R $STACK_USER /opt/stack |
| |
| su -c "/opt/stack/run.sh" $STACK_USER |
| |
| # Update /etc/issue |
| { |
| echo "OpenStack VM - Installed by DevStack" |
| IPADDR=\$(ip -4 address show eth0 | sed -n 's/.*inet \\([0-9\.]\\+\\).*/\1/p') |
| echo " Management IP: \$IPADDR" |
| echo -n " Devstack run: " |
| if [ -e /opt/stack/runsh.succeeded ]; then |
| echo "SUCCEEDED" |
| else |
| echo "FAILED" |
| fi |
| echo "" |
| } > /etc/issue |
| initctl start hvc0 > /dev/null 2>&1 |
| end script |
| EOF |
| |
| # Configure the hostname |
| echo $GUEST_NAME > $STAGING_DIR/etc/hostname |
| |
| # Hostname must resolve for rabbit |
| HOSTS_FILE_IP=$PUB_IP |
| if [ $MGT_IP != "dhcp" ]; then |
| HOSTS_FILE_IP=$MGT_IP |
| fi |
| cat <<EOF >$STAGING_DIR/etc/hosts |
| $HOSTS_FILE_IP $GUEST_NAME |
| 127.0.0.1 localhost localhost.localdomain |
| EOF |
| |
| # Configure the network |
| print_interfaces_config > $STAGING_DIR/etc/network/interfaces |
| |
| # Gracefully cp only if source file/dir exists |
| function cp_it { |
| if [ -e $1 ] || [ -d $1 ]; then |
| cp -pRL $1 $2 |
| fi |
| } |
| |
| # Copy over your ssh keys and env if desired |
| COPYENV=${COPYENV:-1} |
| if [ "$COPYENV" = "1" ]; then |
| cp_it ~/.ssh $STAGING_DIR/opt/stack/.ssh |
| cp_it ~/.ssh/id_rsa.pub $STAGING_DIR/opt/stack/.ssh/authorized_keys |
| cp_it ~/.gitconfig $STAGING_DIR/opt/stack/.gitconfig |
| cp_it ~/.vimrc $STAGING_DIR/opt/stack/.vimrc |
| cp_it ~/.bashrc $STAGING_DIR/opt/stack/.bashrc |
| fi |
| |
| # Configure run.sh |
| cat <<EOF >$STAGING_DIR/opt/stack/run.sh |
| #!/bin/bash |
| set -eux |
| ( |
| flock -n 9 || exit 1 |
| |
| [ -e /opt/stack/runsh.succeeded ] && rm /opt/stack/runsh.succeeded |
| echo \$\$ >> /opt/stack/run_sh.pid |
| |
| cd /opt/stack/devstack |
| ./unstack.sh || true |
| ./stack.sh |
| |
| # Got to the end - success |
| touch /opt/stack/runsh.succeeded |
| rm /opt/stack/run_sh.pid |
| ) 9> /opt/stack/.runsh_lock |
| EOF |
| chmod 755 $STAGING_DIR/opt/stack/run.sh |