blob: 6cb2ca709921dcffc6f8fa3f4fd694831e9e91fa [file] [log] [blame]
John Garbuttdaadf742012-04-27 18:28:28 +01001#!/bin/bash
2
3# This script is run by install_os_domU.sh
4#
5# Parameters:
6# - $GUEST_NAME - hostname for the DomU VM
7#
8# It modifies the ubuntu image created by install_os_domU.sh
9#
10# This script is responsible for cusomtizing the fresh ubuntu
11# image so on boot it runs the prepare_guest.sh script
12# that modifies the VM so it is ready to run stack.sh.
13# It does this by mounting the disk image of the VM.
14#
15# The resultant image is started by install_os_domU.sh,
16# and once the VM has shutdown, build_xva.sh is run
17
John Garbuttdaadf742012-04-27 18:28:28 +010018set -o errexit
Mate Lakat0b3804b2013-05-07 16:58:17 +010019set -o nounset
John Garbuttdaadf742012-04-27 18:28:28 +010020set -o xtrace
21
22# This directory
23TOP_DIR=$(cd $(dirname "$0") && pwd)
24
25# Include onexit commands
26. $TOP_DIR/scripts/on_exit.sh
27
Bob Ballc643ebb2014-02-02 09:16:20 +000028# xapi functions
29. $TOP_DIR/functions
30
John Garbuttdaadf742012-04-27 18:28:28 +010031# Source params - override xenrc params in your localrc to suite your taste
32source xenrc
33
34#
35# Parameters
36#
37GUEST_NAME="$1"
38
39# Mount the VDI
40STAGING_DIR=$($TOP_DIR/scripts/manage-vdi open $GUEST_NAME 0 1 | grep -o "/tmp/tmp.[[:alnum:]]*")
41add_on_exit "$TOP_DIR/scripts/manage-vdi close $GUEST_NAME 0 1"
42
43# Make sure we have a stage
44if [ ! -d $STAGING_DIR/etc ]; then
45 echo "Stage is not properly set up!"
46 exit 1
47fi
48
John Garbuttb6c87142012-08-02 12:34:03 +010049# Copy XenServer tools deb into the VM
50ISO_DIR="/opt/xensource/packages/iso"
51XS_TOOLS_FILE_NAME="xs-tools.deb"
52XS_TOOLS_PATH="/root/$XS_TOOLS_FILE_NAME"
53if [ -e "$ISO_DIR" ]; then
Andrew Melton98ab5002012-09-06 15:18:11 -040054 TOOLS_ISO=$(ls -1 $ISO_DIR/xs-tools-*.iso | head -1)
John Garbuttb6c87142012-08-02 12:34:03 +010055 TMP_DIR=/tmp/temp.$RANDOM
56 mkdir -p $TMP_DIR
57 mount -o loop $TOOLS_ISO $TMP_DIR
58 DEB_FILE=$(ls $TMP_DIR/Linux/*amd64.deb)
59 echo "Copying XenServer tools into VM from: $DEB_FILE"
60 cp $DEB_FILE "${STAGING_DIR}${XS_TOOLS_PATH}"
61 umount $TMP_DIR
62 rm -rf $TMP_DIR
63else
64 echo "WARNING: no XenServer tools found, falling back to 5.6 tools"
Mate Lakatda339822012-11-14 12:45:10 +000065 TOOLS_URL="https://github.com/downloads/citrix-openstack/warehouse/xe-guest-utilities_5.6.100-651_amd64.deb"
Bob Ball82302962014-06-24 11:15:50 +010066 curl --no-sessionid -L -o "$XS_TOOLS_FILE_NAME" $TOOLS_URL
John Garbuttb6c87142012-08-02 12:34:03 +010067 cp $XS_TOOLS_FILE_NAME "${STAGING_DIR}${XS_TOOLS_PATH}"
68 rm -rf $XS_TOOLS_FILE_NAME
69fi
70
John Garbuttdaadf742012-04-27 18:28:28 +010071# Copy prepare_guest.sh to VM
72mkdir -p $STAGING_DIR/opt/stack/
73cp $TOP_DIR/prepare_guest.sh $STAGING_DIR/opt/stack/prepare_guest.sh
74
75# backup rc.local
76cp $STAGING_DIR/etc/rc.local $STAGING_DIR/etc/rc.local.preparebackup
77
78# run prepare_guest.sh on boot
79cat <<EOF >$STAGING_DIR/etc/rc.local
Mate Lakat0b3804b2013-05-07 16:58:17 +010080#!/bin/sh -e
81bash /opt/stack/prepare_guest.sh \\
Mate Lakatd15c8a02014-02-04 12:38:14 +000082 "$GUEST_PASSWORD" "$XS_TOOLS_PATH" "$STACK_USER" "$DOMZERO_USER" \\
Mate Lakat0b3804b2013-05-07 16:58:17 +010083 > /opt/stack/prepare_guest.log 2>&1
John Garbuttdaadf742012-04-27 18:28:28 +010084EOF
Bob Ball60fcfb52013-12-23 17:23:47 +000085
86# Need to set barrier=0 to avoid a Xen bug
87# https://bugs.launchpad.net/ubuntu/+source/linux/+bug/824089
88sed -i -e 's/errors=/barrier=0,errors=/' $STAGING_DIR/etc/fstab
Mate Lakatfff07e82014-10-15 16:42:40 +020089
90# Update ubuntu repositories
91cat > $STAGING_DIR/etc/apt/sources.list << EOF
92deb http://${UBUNTU_INST_HTTP_HOSTNAME}${UBUNTU_INST_HTTP_DIRECTORY} ${UBUNTU_INST_RELEASE} main restricted
93deb-src http://${UBUNTU_INST_HTTP_HOSTNAME}${UBUNTU_INST_HTTP_DIRECTORY} ${UBUNTU_INST_RELEASE} main restricted
94deb http://${UBUNTU_INST_HTTP_HOSTNAME}${UBUNTU_INST_HTTP_DIRECTORY} ${UBUNTU_INST_RELEASE}-updates main restricted
95deb-src http://${UBUNTU_INST_HTTP_HOSTNAME}${UBUNTU_INST_HTTP_DIRECTORY} ${UBUNTU_INST_RELEASE}-updates main restricted
96deb http://${UBUNTU_INST_HTTP_HOSTNAME}${UBUNTU_INST_HTTP_DIRECTORY} ${UBUNTU_INST_RELEASE} universe
97deb-src http://${UBUNTU_INST_HTTP_HOSTNAME}${UBUNTU_INST_HTTP_DIRECTORY} ${UBUNTU_INST_RELEASE} universe
98deb http://${UBUNTU_INST_HTTP_HOSTNAME}${UBUNTU_INST_HTTP_DIRECTORY} ${UBUNTU_INST_RELEASE}-updates universe
99deb-src http://${UBUNTU_INST_HTTP_HOSTNAME}${UBUNTU_INST_HTTP_DIRECTORY} ${UBUNTU_INST_RELEASE}-updates universe
100deb http://${UBUNTU_INST_HTTP_HOSTNAME}${UBUNTU_INST_HTTP_DIRECTORY} ${UBUNTU_INST_RELEASE} multiverse
101deb-src http://${UBUNTU_INST_HTTP_HOSTNAME}${UBUNTU_INST_HTTP_DIRECTORY} ${UBUNTU_INST_RELEASE} multiverse
102deb http://${UBUNTU_INST_HTTP_HOSTNAME}${UBUNTU_INST_HTTP_DIRECTORY} ${UBUNTU_INST_RELEASE}-updates multiverse
103deb-src http://${UBUNTU_INST_HTTP_HOSTNAME}${UBUNTU_INST_HTTP_DIRECTORY} ${UBUNTU_INST_RELEASE}-updates multiverse
104deb http://${UBUNTU_INST_HTTP_HOSTNAME}${UBUNTU_INST_HTTP_DIRECTORY} ${UBUNTU_INST_RELEASE}-backports main restricted universe multiverse
105deb-src http://${UBUNTU_INST_HTTP_HOSTNAME}${UBUNTU_INST_HTTP_DIRECTORY} ${UBUNTU_INST_RELEASE}-backports main restricted universe multiverse
106
107deb http://security.ubuntu.com/ubuntu ${UBUNTU_INST_RELEASE}-security main restricted
108deb-src http://security.ubuntu.com/ubuntu ${UBUNTU_INST_RELEASE}-security main restricted
109deb http://security.ubuntu.com/ubuntu ${UBUNTU_INST_RELEASE}-security universe
110deb-src http://security.ubuntu.com/ubuntu ${UBUNTU_INST_RELEASE}-security universe
111deb http://security.ubuntu.com/ubuntu ${UBUNTU_INST_RELEASE}-security multiverse
112deb-src http://security.ubuntu.com/ubuntu ${UBUNTU_INST_RELEASE}-security multiverse
113EOF
Mate Lakate35785d2014-10-16 15:40:03 +0200114
115rm -f $STAGING_DIR/etc/apt/apt.conf
116if [ -n "$UBUNTU_INST_HTTP_PROXY" ]; then
117 cat > $STAGING_DIR/etc/apt/apt.conf << EOF
118Acquire::http::Proxy "$UBUNTU_INST_HTTP_PROXY";
119EOF
120fi