| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 1 | #!/bin/bash | 
|  | 2 |  | 
| Mate Lakat | 0b3804b | 2013-05-07 16:58:17 +0100 | [diff] [blame] | 3 | # This script must be run on a XenServer or XCP machine | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 4 | # | 
|  | 5 | # It creates a DomU VM that runs OpenStack services | 
|  | 6 | # | 
|  | 7 | # For more details see: README.md | 
|  | 8 |  | 
| Renuka Apte | 0af143b | 2012-04-02 15:46:53 -0700 | [diff] [blame] | 9 | set -o errexit | 
| Mate Lakat | 0b3804b | 2013-05-07 16:58:17 +0100 | [diff] [blame] | 10 | set -o nounset | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 11 | set -o xtrace | 
| Renuka Apte | 0af143b | 2012-04-02 15:46:53 -0700 | [diff] [blame] | 12 |  | 
| Mate Lakat | 1ca490c | 2013-09-19 10:03:36 +0100 | [diff] [blame] | 13 | export LC_ALL=C | 
|  | 14 |  | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 15 | # Abort if localrc is not set | 
|  | 16 | if [ ! -e ../../localrc ]; then | 
|  | 17 | echo "You must have a localrc with ALL necessary passwords defined before proceeding." | 
|  | 18 | echo "See the xen README for required passwords." | 
|  | 19 | exit 1 | 
|  | 20 | fi | 
|  | 21 |  | 
| Anthony Young | af6ed6b | 2011-11-02 07:50:27 -0500 | [diff] [blame] | 22 | # This directory | 
| Mate Lakat | a8bf0f2 | 2013-03-07 18:37:31 +0000 | [diff] [blame] | 23 | THIS_DIR=$(cd $(dirname "$0") && pwd) | 
| Anthony Young | af6ed6b | 2011-11-02 07:50:27 -0500 | [diff] [blame] | 24 |  | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 25 | # Include onexit commands | 
| Mate Lakat | a8bf0f2 | 2013-03-07 18:37:31 +0000 | [diff] [blame] | 26 | . $THIS_DIR/scripts/on_exit.sh | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 27 |  | 
| Mate Lakat | 57e3da9 | 2013-03-22 16:34:05 +0000 | [diff] [blame] | 28 | # xapi functions | 
|  | 29 | . $THIS_DIR/functions | 
|  | 30 |  | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 31 | # | 
|  | 32 | # Get Settings | 
|  | 33 | # | 
|  | 34 |  | 
| Anthony Young | b3e2f33 | 2012-03-16 17:01:49 -0700 | [diff] [blame] | 35 | # Source params - override xenrc params in your localrc to suit your taste | 
| Mate Lakat | 0b3804b | 2013-05-07 16:58:17 +0100 | [diff] [blame] | 36 | source $THIS_DIR/xenrc | 
| Anthony Young | af6ed6b | 2011-11-02 07:50:27 -0500 | [diff] [blame] | 37 |  | 
| Renuka Apte | 0af143b | 2012-04-02 15:46:53 -0700 | [diff] [blame] | 38 | xe_min() | 
|  | 39 | { | 
| Sean Dague | 0b865a5 | 2013-10-22 11:37:35 -0400 | [diff] [blame] | 40 | local cmd="$1" | 
|  | 41 | shift | 
|  | 42 | xe "$cmd" --minimal "$@" | 
| Renuka Apte | 0af143b | 2012-04-02 15:46:53 -0700 | [diff] [blame] | 43 | } | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 44 |  | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 45 | # | 
|  | 46 | # Prepare Dom0 | 
|  | 47 | # including installing XenAPI plugins | 
|  | 48 | # | 
|  | 49 |  | 
| Mate Lakat | a8bf0f2 | 2013-03-07 18:37:31 +0000 | [diff] [blame] | 50 | cd $THIS_DIR | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 51 |  | 
| Mate Lakat | d851103 | 2013-07-03 10:44:44 +0100 | [diff] [blame] | 52 | # Die if multiple hosts listed | 
|  | 53 | if have_multiple_hosts; then | 
|  | 54 | cat >&2 << EOF | 
|  | 55 | ERROR: multiple hosts found. This might mean that the XenServer is a member | 
|  | 56 | of a pool - Exiting. | 
|  | 57 | EOF | 
|  | 58 | exit 1 | 
|  | 59 | fi | 
|  | 60 |  | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 61 | # | 
|  | 62 | # Configure Networking | 
|  | 63 | # | 
| Bob Ball | 78ef1f3 | 2013-09-29 11:36:28 +0100 | [diff] [blame] | 64 |  | 
|  | 65 | MGT_NETWORK=`xe pif-list management=true params=network-uuid minimal=true` | 
|  | 66 | MGT_BRIDGE_OR_NET_NAME=`xe network-list uuid=$MGT_NETWORK params=bridge minimal=true` | 
|  | 67 |  | 
| Mate Lakat | 9e32677 | 2013-05-08 16:42:22 +0100 | [diff] [blame] | 68 | setup_network "$VM_BRIDGE_OR_NET_NAME" | 
|  | 69 | setup_network "$MGT_BRIDGE_OR_NET_NAME" | 
|  | 70 | setup_network "$PUB_BRIDGE_OR_NET_NAME" | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 71 |  | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 72 | # With neutron, one more network is required, which is internal to the | 
| Mate Lakat | f652e0f | 2013-05-21 18:12:48 +0100 | [diff] [blame] | 73 | # hypervisor, and used by the VMs | 
| Mate Lakat | 6df6489 | 2014-10-17 13:09:49 +0200 | [diff] [blame] | 74 | setup_network "$XEN_INT_BRIDGE_OR_NET_NAME" | 
| Mate Lakat | f652e0f | 2013-05-21 18:12:48 +0100 | [diff] [blame] | 75 |  | 
| Mate Lakat | 9e32677 | 2013-05-08 16:42:22 +0100 | [diff] [blame] | 76 | if parameter_is_specified "FLAT_NETWORK_BRIDGE"; then | 
| Mate Lakat | 2b8814d | 2013-09-25 17:07:06 +0100 | [diff] [blame] | 77 | if [ "$(bridge_for "$VM_BRIDGE_OR_NET_NAME")" != "$(bridge_for "$FLAT_NETWORK_BRIDGE")" ]; then | 
|  | 78 | cat >&2 << EOF | 
|  | 79 | ERROR: FLAT_NETWORK_BRIDGE is specified in localrc file, and either no network | 
|  | 80 | found on XenServer by searching for networks by that value as name-label or | 
|  | 81 | bridge name or the network found does not match the network specified by | 
|  | 82 | VM_BRIDGE_OR_NET_NAME. Please check your localrc file. | 
| Mate Lakat | 9e32677 | 2013-05-08 16:42:22 +0100 | [diff] [blame] | 83 | EOF | 
| Mate Lakat | 2b8814d | 2013-09-25 17:07:06 +0100 | [diff] [blame] | 84 | exit 1 | 
|  | 85 | fi | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 86 | fi | 
|  | 87 |  | 
| Mate Lakat | 9e32677 | 2013-05-08 16:42:22 +0100 | [diff] [blame] | 88 | if ! xenapi_is_listening_on "$MGT_BRIDGE_OR_NET_NAME"; then | 
|  | 89 | cat >&2 << EOF | 
|  | 90 | ERROR: XenAPI does not have an assigned IP address on the management network. | 
|  | 91 | please review your XenServer network configuration / localrc file. | 
|  | 92 | EOF | 
|  | 93 | exit 1 | 
|  | 94 | fi | 
|  | 95 |  | 
|  | 96 | HOST_IP=$(xenapi_ip_on "$MGT_BRIDGE_OR_NET_NAME") | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 97 |  | 
|  | 98 | # Set up ip forwarding, but skip on xcp-xapi | 
| John Garbutt | d8f1a87 | 2012-06-26 11:16:38 +0100 | [diff] [blame] | 99 | if [ -a /etc/sysconfig/network ]; then | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 100 | if ! grep -q "FORWARD_IPV4=YES" /etc/sysconfig/network; then | 
| Sean Dague | 0b865a5 | 2013-10-22 11:37:35 -0400 | [diff] [blame] | 101 | # FIXME: This doesn't work on reboot! | 
|  | 102 | echo "FORWARD_IPV4=YES" >> /etc/sysconfig/network | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 103 | fi | 
|  | 104 | fi | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 105 | # Also, enable ip forwarding in rc.local, since the above trick isn't working | 
|  | 106 | if ! grep -q  "echo 1 >/proc/sys/net/ipv4/ip_forward" /etc/rc.local; then | 
|  | 107 | echo "echo 1 >/proc/sys/net/ipv4/ip_forward" >> /etc/rc.local | 
|  | 108 | fi | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 109 | # Enable ip forwarding at runtime as well | 
|  | 110 | echo 1 > /proc/sys/net/ipv4/ip_forward | 
|  | 111 |  | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 112 |  | 
|  | 113 | # | 
| Anthony Young | 346e491 | 2011-11-05 00:22:47 -0500 | [diff] [blame] | 114 | # Shutdown previous runs | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 115 | # | 
|  | 116 |  | 
| Anthony Young | 346e491 | 2011-11-05 00:22:47 -0500 | [diff] [blame] | 117 | DO_SHUTDOWN=${DO_SHUTDOWN:-1} | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 118 | CLEAN_TEMPLATES=${CLEAN_TEMPLATES:-false} | 
| Anthony Young | 346e491 | 2011-11-05 00:22:47 -0500 | [diff] [blame] | 119 | if [ "$DO_SHUTDOWN" = "1" ]; then | 
| Anthony Young | 40b5737 | 2011-11-05 00:30:07 -0500 | [diff] [blame] | 120 | # Shutdown all domU's that created previously | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 121 | clean_templates_arg="" | 
|  | 122 | if $CLEAN_TEMPLATES; then | 
|  | 123 | clean_templates_arg="--remove-templates" | 
|  | 124 | fi | 
|  | 125 | ./scripts/uninstall-os-vpx.sh $clean_templates_arg | 
| Anthony Young | 346e491 | 2011-11-05 00:22:47 -0500 | [diff] [blame] | 126 |  | 
|  | 127 | # Destroy any instances that were launched | 
|  | 128 | for uuid in `xe vm-list | grep -1 instance | grep uuid | sed "s/.*\: //g"`; do | 
|  | 129 | echo "Shutting down nova instance $uuid" | 
| Mate Lakat | 0d97cbe | 2013-07-29 09:41:50 +0100 | [diff] [blame] | 130 | xe vm-uninstall uuid=$uuid force=true | 
| Anthony Young | 346e491 | 2011-11-05 00:22:47 -0500 | [diff] [blame] | 131 | done | 
| Anthony Young | fa4ecc6 | 2011-11-11 10:23:22 -0800 | [diff] [blame] | 132 |  | 
|  | 133 | # Destroy orphaned vdis | 
|  | 134 | for uuid in `xe vdi-list | grep -1 Glance | grep uuid | sed "s/.*\: //g"`; do | 
|  | 135 | xe vdi-destroy uuid=$uuid | 
|  | 136 | done | 
| Anthony Young | 346e491 | 2011-11-05 00:22:47 -0500 | [diff] [blame] | 137 | fi | 
| Anthony Young | b62b4ca | 2011-10-26 22:29:08 -0700 | [diff] [blame] | 138 |  | 
| Renuka Apte | 0af143b | 2012-04-02 15:46:53 -0700 | [diff] [blame] | 139 |  | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 140 | # | 
|  | 141 | # Create Ubuntu VM template | 
|  | 142 | # and/or create VM from template | 
|  | 143 | # | 
| Renuka Apte | 0af143b | 2012-04-02 15:46:53 -0700 | [diff] [blame] | 144 |  | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 145 | GUEST_NAME=${GUEST_NAME:-"DevStackOSDomU"} | 
| Mate Lakat | c02b2f8 | 2013-07-30 19:43:10 +0100 | [diff] [blame] | 146 | TNAME="jeos_template_for_devstack" | 
|  | 147 | SNAME_TEMPLATE="jeos_snapshot_for_devstack" | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 148 | SNAME_FIRST_BOOT="before_first_boot" | 
|  | 149 |  | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 150 | function wait_for_VM_to_halt { | 
| Bob Ball | 63c6c2b | 2013-01-24 13:13:51 +0000 | [diff] [blame] | 151 | set +x | 
|  | 152 | echo "Waiting for the VM to halt.  Progress in-VM can be checked with vncviewer:" | 
|  | 153 | mgmt_ip=$(echo $XENAPI_CONNECTION_URL | tr -d -c '1234567890.') | 
| Mate Lakat | d15c8a0 | 2014-02-04 12:38:14 +0000 | [diff] [blame] | 154 | domid=$(get_domid "$GUEST_NAME") | 
| Bob Ball | 6a95b60 | 2014-09-17 12:39:50 +0100 | [diff] [blame] | 155 | sleep 20 # Wait for the vnc-port to be written | 
| Bob Ball | 63c6c2b | 2013-01-24 13:13:51 +0000 | [diff] [blame] | 156 | port=$(xenstore-read /local/domain/$domid/console/vnc-port) | 
| Mate Lakat | 97621a1 | 2013-08-30 13:12:17 +0100 | [diff] [blame] | 157 | echo "vncviewer -via root@$mgmt_ip localhost:${port:2}" | 
| Chmouel Boudjnah | 86a8e97 | 2014-02-04 15:20:15 +0100 | [diff] [blame] | 158 | while true; do | 
| Renuka Apte | 0af143b | 2012-04-02 15:46:53 -0700 | [diff] [blame] | 159 | state=$(xe_min vm-list name-label="$GUEST_NAME" power-state=halted) | 
| Sean Dague | 16dd8b3 | 2014-02-03 09:10:54 +0900 | [diff] [blame] | 160 | if [ -n "$state" ]; then | 
| Renuka Apte | 0af143b | 2012-04-02 15:46:53 -0700 | [diff] [blame] | 161 | break | 
|  | 162 | else | 
| Bob Ball | 63c6c2b | 2013-01-24 13:13:51 +0000 | [diff] [blame] | 163 | echo -n "." | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 164 | sleep 20 | 
| Renuka Apte | 0af143b | 2012-04-02 15:46:53 -0700 | [diff] [blame] | 165 | fi | 
|  | 166 | done | 
| Bob Ball | 63c6c2b | 2013-01-24 13:13:51 +0000 | [diff] [blame] | 167 | set -x | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 168 | } | 
| Renuka Apte | 0af143b | 2012-04-02 15:46:53 -0700 | [diff] [blame] | 169 |  | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 170 | templateuuid=$(xe template-list name-label="$TNAME") | 
|  | 171 | if [ -z "$templateuuid" ]; then | 
|  | 172 | # | 
|  | 173 | # Install Ubuntu over network | 
|  | 174 | # | 
| Bob Ball | 78ef1f3 | 2013-09-29 11:36:28 +0100 | [diff] [blame] | 175 | UBUNTU_INST_BRIDGE_OR_NET_NAME=${UBUNTU_INST_BRIDGE_OR_NET_NAME:-"$MGT_BRIDGE_OR_NET_NAME"} | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 176 |  | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 177 | # always update the preseed file, incase we have a newer one | 
|  | 178 | PRESEED_URL=${PRESEED_URL:-""} | 
|  | 179 | if [ -z "$PRESEED_URL" ]; then | 
|  | 180 | PRESEED_URL="${HOST_IP}/devstackubuntupreseed.cfg" | 
| Bob Ball | 5b9adb6 | 2015-02-10 08:09:08 +0000 | [diff] [blame] | 181 |  | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 182 | HTTP_SERVER_LOCATION="/opt/xensource/www" | 
|  | 183 | if [ ! -e $HTTP_SERVER_LOCATION ]; then | 
|  | 184 | HTTP_SERVER_LOCATION="/var/www/html" | 
|  | 185 | mkdir -p $HTTP_SERVER_LOCATION | 
|  | 186 | fi | 
| Bob Ball | 5b9adb6 | 2015-02-10 08:09:08 +0000 | [diff] [blame] | 187 |  | 
|  | 188 | # Copy the tools DEB to the XS web server | 
|  | 189 | XS_TOOLS_URL="https://github.com/downloads/citrix-openstack/warehouse/xe-guest-utilities_5.6.100-651_amd64.deb" | 
|  | 190 | ISO_DIR="/opt/xensource/packages/iso" | 
|  | 191 | XS_TOOLS_FILE_NAME="xs-tools.deb" | 
|  | 192 | XS_TOOLS_PATH="/root/$XS_TOOLS_FILE_NAME" | 
|  | 193 | if [ -e "$ISO_DIR" ]; then | 
|  | 194 | TOOLS_ISO=$(ls -1 $ISO_DIR/xs-tools-*.iso | head -1) | 
|  | 195 | TMP_DIR=/tmp/temp.$RANDOM | 
|  | 196 | mkdir -p $TMP_DIR | 
|  | 197 | mount -o loop $TOOLS_ISO $TMP_DIR | 
|  | 198 | DEB_FILE=$(ls $TMP_DIR/Linux/*amd64.deb) | 
|  | 199 | cp $DEB_FILE $HTTP_SERVER_LOCATION | 
|  | 200 | umount $TMP_DIR | 
|  | 201 | rmdir $TMP_DIR | 
|  | 202 | XS_TOOLS_URL=${HOST_IP}/$(basename $DEB_FILE) | 
|  | 203 | fi | 
|  | 204 |  | 
| Mate Lakat | a8bf0f2 | 2013-03-07 18:37:31 +0000 | [diff] [blame] | 205 | cp -f $THIS_DIR/devstackubuntupreseed.cfg $HTTP_SERVER_LOCATION | 
| Bob Ball | 5b9adb6 | 2015-02-10 08:09:08 +0000 | [diff] [blame] | 206 | cp -f $THIS_DIR/devstackubuntu_latecommand.sh $HTTP_SERVER_LOCATION/latecommand.sh | 
| Mate Lakat | d3740f7 | 2013-05-09 15:02:21 +0100 | [diff] [blame] | 207 |  | 
|  | 208 | sed \ | 
|  | 209 | -e "s,\(d-i mirror/http/hostname string\).*,\1 $UBUNTU_INST_HTTP_HOSTNAME,g" \ | 
|  | 210 | -e "s,\(d-i mirror/http/directory string\).*,\1 $UBUNTU_INST_HTTP_DIRECTORY,g" \ | 
|  | 211 | -e "s,\(d-i mirror/http/proxy string\).*,\1 $UBUNTU_INST_HTTP_PROXY,g" \ | 
| Bob Ball | 105eaee | 2014-07-14 15:21:07 +0100 | [diff] [blame] | 212 | -e "s,\(d-i passwd/root-password password\).*,\1 $GUEST_PASSWORD,g" \ | 
|  | 213 | -e "s,\(d-i passwd/root-password-again password\).*,\1 $GUEST_PASSWORD,g" \ | 
| Bob Ball | 5b9adb6 | 2015-02-10 08:09:08 +0000 | [diff] [blame] | 214 | -e "s,\(d-i preseed/late_command string\).*,\1 in-target mkdir -p /tmp; in-target wget --no-proxy ${HOST_IP}/latecommand.sh -O /root/latecommand.sh; in-target bash /root/latecommand.sh,g" \ | 
| Mate Lakat | d3740f7 | 2013-05-09 15:02:21 +0100 | [diff] [blame] | 215 | -i "${HTTP_SERVER_LOCATION}/devstackubuntupreseed.cfg" | 
| Bob Ball | 5b9adb6 | 2015-02-10 08:09:08 +0000 | [diff] [blame] | 216 |  | 
|  | 217 | sed \ | 
|  | 218 | -e "s,@XS_TOOLS_URL@,$XS_TOOLS_URL,g" \ | 
|  | 219 | -i "${HTTP_SERVER_LOCATION}/latecommand.sh" | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 220 | fi | 
|  | 221 |  | 
| John Garbutt | d8f1a87 | 2012-06-26 11:16:38 +0100 | [diff] [blame] | 222 | # Update the template | 
| Mate Lakat | a8bf0f2 | 2013-03-07 18:37:31 +0000 | [diff] [blame] | 223 | $THIS_DIR/scripts/install_ubuntu_template.sh $PRESEED_URL | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 224 |  | 
| Mate Lakat | 2f524bd | 2013-06-19 12:32:23 +0100 | [diff] [blame] | 225 | # create a new VM from the given template with eth0 attached to the given | 
|  | 226 | # network | 
| Mate Lakat | 9e32677 | 2013-05-08 16:42:22 +0100 | [diff] [blame] | 227 | $THIS_DIR/scripts/install-os-vpx.sh \ | 
|  | 228 | -t "$UBUNTU_INST_TEMPLATE_NAME" \ | 
| Mate Lakat | 2f524bd | 2013-06-19 12:32:23 +0100 | [diff] [blame] | 229 | -n "$UBUNTU_INST_BRIDGE_OR_NET_NAME" \ | 
| Mate Lakat | 16ed068 | 2013-08-30 13:28:31 +0100 | [diff] [blame] | 230 | -l "$GUEST_NAME" | 
|  | 231 |  | 
|  | 232 | set_vm_memory "$GUEST_NAME" "$OSDOMU_MEM_MB" | 
|  | 233 |  | 
|  | 234 | xe vm-start vm="$GUEST_NAME" | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 235 |  | 
|  | 236 | # wait for install to finish | 
|  | 237 | wait_for_VM_to_halt | 
|  | 238 |  | 
|  | 239 | # set VM to restart after a reboot | 
| Renuka Apte | 0af143b | 2012-04-02 15:46:53 -0700 | [diff] [blame] | 240 | vm_uuid=$(xe_min vm-list name-label="$GUEST_NAME") | 
|  | 241 | xe vm-param-set actions-after-reboot=Restart uuid="$vm_uuid" | 
|  | 242 |  | 
|  | 243 | # Make template from VM | 
| Mate Lakat | c02b2f8 | 2013-07-30 19:43:10 +0100 | [diff] [blame] | 244 | snuuid=$(xe vm-snapshot vm="$GUEST_NAME" new-name-label="$SNAME_TEMPLATE") | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 245 | xe snapshot-clone uuid=$snuuid new-name-label="$TNAME" | 
|  | 246 | else | 
|  | 247 | # | 
|  | 248 | # Template already installed, create VM from template | 
|  | 249 | # | 
|  | 250 | vm_uuid=$(xe vm-install template="$TNAME" new-name-label="$GUEST_NAME") | 
| Renuka Apte | 0af143b | 2012-04-02 15:46:53 -0700 | [diff] [blame] | 251 | fi | 
|  | 252 |  | 
| Mate Lakat | 2a324dd | 2014-10-15 17:40:41 +0200 | [diff] [blame] | 253 | if [ -n "${EXIT_AFTER_JEOS_INSTALLATION:-}" ]; then | 
|  | 254 | echo "User requested to quit after JEOS instalation" | 
|  | 255 | exit 0 | 
|  | 256 | fi | 
|  | 257 |  | 
| Mate Lakat | c02b2f8 | 2013-07-30 19:43:10 +0100 | [diff] [blame] | 258 | # | 
|  | 259 | # Prepare VM for DevStack | 
|  | 260 | # | 
| Bob Ball | 0df75a7 | 2015-02-12 11:59:46 +0000 | [diff] [blame] | 261 | xe vm-param-set other-config:os-vpx=true uuid="$vm_uuid" | 
| Mate Lakat | c02b2f8 | 2013-07-30 19:43:10 +0100 | [diff] [blame] | 262 |  | 
|  | 263 | # Install XenServer tools, and other such things | 
|  | 264 | $THIS_DIR/prepare_guest_template.sh "$GUEST_NAME" | 
|  | 265 |  | 
| Mate Lakat | 16ed068 | 2013-08-30 13:28:31 +0100 | [diff] [blame] | 266 | # Set virtual machine parameters | 
|  | 267 | set_vm_memory "$GUEST_NAME" "$OSDOMU_MEM_MB" | 
|  | 268 |  | 
| Mate Lakat | 9f878cb | 2013-10-04 09:56:24 +0100 | [diff] [blame] | 269 | # Max out VCPU count for better performance | 
|  | 270 | max_vcpus "$GUEST_NAME" | 
|  | 271 |  | 
| Mate Lakat | 8787e0f | 2013-10-28 18:15:57 +0000 | [diff] [blame] | 272 | # Wipe out all network cards | 
|  | 273 | destroy_all_vifs_of "$GUEST_NAME" | 
|  | 274 |  | 
|  | 275 | # Add only one interface to prepare the guest template | 
|  | 276 | add_interface "$GUEST_NAME" "$MGT_BRIDGE_OR_NET_NAME" "0" | 
|  | 277 |  | 
| Mate Lakat | c02b2f8 | 2013-07-30 19:43:10 +0100 | [diff] [blame] | 278 | # start the VM to run the prepare steps | 
|  | 279 | xe vm-start vm="$GUEST_NAME" | 
|  | 280 |  | 
|  | 281 | # Wait for prep script to finish and shutdown system | 
|  | 282 | wait_for_VM_to_halt | 
|  | 283 |  | 
| Mate Lakat | 5a56cd6 | 2013-06-17 13:54:43 +0100 | [diff] [blame] | 284 | ## Setup network cards | 
|  | 285 | # Wipe out all | 
|  | 286 | destroy_all_vifs_of "$GUEST_NAME" | 
|  | 287 | # Tenant network | 
|  | 288 | add_interface "$GUEST_NAME" "$VM_BRIDGE_OR_NET_NAME" "$VM_DEV_NR" | 
|  | 289 | # Management network | 
|  | 290 | add_interface "$GUEST_NAME" "$MGT_BRIDGE_OR_NET_NAME" "$MGT_DEV_NR" | 
|  | 291 | # Public network | 
|  | 292 | add_interface "$GUEST_NAME" "$PUB_BRIDGE_OR_NET_NAME" "$PUB_DEV_NR" | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 293 |  | 
|  | 294 | # | 
|  | 295 | # Inject DevStack inside VM disk | 
|  | 296 | # | 
| Mate Lakat | a8bf0f2 | 2013-03-07 18:37:31 +0000 | [diff] [blame] | 297 | $THIS_DIR/build_xva.sh "$GUEST_NAME" | 
| Renuka Apte | 0af143b | 2012-04-02 15:46:53 -0700 | [diff] [blame] | 298 |  | 
| Mate Lakat | f652e0f | 2013-05-21 18:12:48 +0100 | [diff] [blame] | 299 | # Attach a network interface for the integration network (so that the bridge | 
| Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 300 | # is created by XenServer). This is required for Neutron. Also pass that as a | 
| Mate Lakat | 8ff33ce | 2013-05-30 13:26:58 +0100 | [diff] [blame] | 301 | # kernel parameter for DomU | 
| Mate Lakat | 6df6489 | 2014-10-17 13:09:49 +0200 | [diff] [blame] | 302 | attach_network "$XEN_INT_BRIDGE_OR_NET_NAME" | 
| Mate Lakat | 8ff33ce | 2013-05-30 13:26:58 +0100 | [diff] [blame] | 303 |  | 
| Mate Lakat | 6df6489 | 2014-10-17 13:09:49 +0200 | [diff] [blame] | 304 | XEN_INTEGRATION_BRIDGE=$(bridge_for "$XEN_INT_BRIDGE_OR_NET_NAME") | 
|  | 305 | append_kernel_cmdline \ | 
|  | 306 | "$GUEST_NAME" \ | 
|  | 307 | "xen_integration_bridge=${XEN_INTEGRATION_BRIDGE}" | 
| Mate Lakat | f652e0f | 2013-05-21 18:12:48 +0100 | [diff] [blame] | 308 |  | 
| Mate Lakat | 2b8814d | 2013-09-25 17:07:06 +0100 | [diff] [blame] | 309 | FLAT_NETWORK_BRIDGE="${FLAT_NETWORK_BRIDGE:-$(bridge_for "$VM_BRIDGE_OR_NET_NAME")}" | 
| Mate Lakat | 8ff33ce | 2013-05-30 13:26:58 +0100 | [diff] [blame] | 310 | append_kernel_cmdline "$GUEST_NAME" "flat_network_bridge=${FLAT_NETWORK_BRIDGE}" | 
|  | 311 |  | 
| Mate Lakat | 68ac03c | 2013-06-06 16:22:34 +0100 | [diff] [blame] | 312 | # Add a separate xvdb, if it was requested | 
|  | 313 | if [[ "0" != "$XEN_XVDB_SIZE_GB" ]]; then | 
|  | 314 | vm=$(xe vm-list name-label="$GUEST_NAME" --minimal) | 
|  | 315 |  | 
|  | 316 | # Add a new disk | 
|  | 317 | localsr=$(get_local_sr) | 
|  | 318 | extra_vdi=$(xe vdi-create \ | 
|  | 319 | name-label=xvdb-added-by-devstack \ | 
|  | 320 | virtual-size="${XEN_XVDB_SIZE_GB}GiB" \ | 
|  | 321 | sr-uuid=$localsr type=user) | 
|  | 322 | xe vbd-create vm-uuid=$vm vdi-uuid=$extra_vdi device=1 | 
|  | 323 | fi | 
|  | 324 |  | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 325 | # create a snapshot before the first boot | 
|  | 326 | # to allow a quick re-run with the same settings | 
|  | 327 | xe vm-snapshot vm="$GUEST_NAME" new-name-label="$SNAME_FIRST_BOOT" | 
|  | 328 |  | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 329 | # | 
|  | 330 | # Run DevStack VM | 
|  | 331 | # | 
| Renuka Apte | 0af143b | 2012-04-02 15:46:53 -0700 | [diff] [blame] | 332 | xe vm-start vm="$GUEST_NAME" | 
| Anthony Young | 3eb8f59 | 2011-10-26 23:11:52 -0700 | [diff] [blame] | 333 |  | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 334 | function ssh_no_check { | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 335 | ssh -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no "$@" | 
|  | 336 | } | 
|  | 337 |  | 
| Mate Lakat | 8644676 | 2013-05-12 18:34:29 +0100 | [diff] [blame] | 338 | # Get hold of the Management IP of OpenStack VM | 
|  | 339 | OS_VM_MANAGEMENT_ADDRESS=$MGT_IP | 
|  | 340 | if [ $OS_VM_MANAGEMENT_ADDRESS == "dhcp" ]; then | 
| Mate Lakat | 5a56cd6 | 2013-06-17 13:54:43 +0100 | [diff] [blame] | 341 | OS_VM_MANAGEMENT_ADDRESS=$(find_ip_by_name $GUEST_NAME $MGT_DEV_NR) | 
| Mate Lakat | 8644676 | 2013-05-12 18:34:29 +0100 | [diff] [blame] | 342 | fi | 
|  | 343 |  | 
|  | 344 | # Get hold of the Service IP of OpenStack VM | 
| Mate Lakat | 5a56cd6 | 2013-06-17 13:54:43 +0100 | [diff] [blame] | 345 | if [ $HOST_IP_IFACE == "eth${MGT_DEV_NR}" ]; then | 
| Mate Lakat | 8644676 | 2013-05-12 18:34:29 +0100 | [diff] [blame] | 346 | OS_VM_SERVICES_ADDRESS=$MGT_IP | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 347 | if [ $MGT_IP == "dhcp" ]; then | 
| Mate Lakat | 5a56cd6 | 2013-06-17 13:54:43 +0100 | [diff] [blame] | 348 | OS_VM_SERVICES_ADDRESS=$(find_ip_by_name $GUEST_NAME $MGT_DEV_NR) | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 349 | fi | 
|  | 350 | else | 
| Mate Lakat | 8644676 | 2013-05-12 18:34:29 +0100 | [diff] [blame] | 351 | OS_VM_SERVICES_ADDRESS=$PUB_IP | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 352 | if [ $PUB_IP == "dhcp" ]; then | 
| Mate Lakat | 5a56cd6 | 2013-06-17 13:54:43 +0100 | [diff] [blame] | 353 | OS_VM_SERVICES_ADDRESS=$(find_ip_by_name $GUEST_NAME $PUB_DEV_NR) | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 354 | fi | 
| Renuka Apte | c56885a | 2012-02-29 16:09:26 -0800 | [diff] [blame] | 355 | fi | 
|  | 356 |  | 
| Mate Lakat | d15c8a0 | 2014-02-04 12:38:14 +0000 | [diff] [blame] | 357 | # Create an ssh-keypair, and set it up for dom0 user | 
|  | 358 | rm -f /root/dom0key /root/dom0key.pub | 
|  | 359 | ssh-keygen -f /root/dom0key -P "" -C "dom0" | 
|  | 360 | DOMID=$(get_domid "$GUEST_NAME") | 
|  | 361 |  | 
|  | 362 | xenstore-write /local/domain/$DOMID/authorized_keys/$DOMZERO_USER "$(cat /root/dom0key.pub)" | 
|  | 363 | xenstore-chmod -u /local/domain/$DOMID/authorized_keys/$DOMZERO_USER r$DOMID | 
|  | 364 |  | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 365 | function run_on_appliance { | 
| Mate Lakat | d15c8a0 | 2014-02-04 12:38:14 +0000 | [diff] [blame] | 366 | ssh \ | 
|  | 367 | -i /root/dom0key \ | 
|  | 368 | -o UserKnownHostsFile=/dev/null \ | 
|  | 369 | -o StrictHostKeyChecking=no \ | 
|  | 370 | -o BatchMode=yes \ | 
|  | 371 | "$DOMZERO_USER@$OS_VM_MANAGEMENT_ADDRESS" "$@" | 
|  | 372 | } | 
|  | 373 |  | 
|  | 374 | # Wait until we can log in to the appliance | 
|  | 375 | while ! run_on_appliance true; do | 
|  | 376 | sleep 1 | 
|  | 377 | done | 
|  | 378 |  | 
|  | 379 | # Remove authenticated_keys updater cronjob | 
|  | 380 | echo "" | run_on_appliance crontab - | 
|  | 381 |  | 
|  | 382 | # Generate a passwordless ssh key for domzero user | 
|  | 383 | echo "ssh-keygen -f /home/$DOMZERO_USER/.ssh/id_rsa -C $DOMZERO_USER@appliance -N \"\" -q" | run_on_appliance | 
|  | 384 |  | 
|  | 385 | # Authenticate that user to dom0 | 
|  | 386 | run_on_appliance cat /home/$DOMZERO_USER/.ssh/id_rsa.pub >> /root/.ssh/authorized_keys | 
|  | 387 |  | 
| Anthony Young | 1de18c6 | 2011-11-01 14:19:18 -0500 | [diff] [blame] | 388 | # If we have copied our ssh credentials, use ssh to monitor while the installation runs | 
|  | 389 | WAIT_TILL_LAUNCH=${WAIT_TILL_LAUNCH:-1} | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 390 | COPYENV=${COPYENV:-1} | 
| Anthony Young | 1de18c6 | 2011-11-01 14:19:18 -0500 | [diff] [blame] | 391 | if [ "$WAIT_TILL_LAUNCH" = "1" ]  && [ -e ~/.ssh/id_rsa.pub  ] && [ "$COPYENV" = "1" ]; then | 
| Bob Ball | 7fcc157 | 2013-02-20 15:56:25 +0000 | [diff] [blame] | 392 | set +x | 
| Anthony Young | 1de18c6 | 2011-11-01 14:19:18 -0500 | [diff] [blame] | 393 |  | 
| Bob Ball | 0686dae | 2015-01-15 12:48:26 +0000 | [diff] [blame] | 394 | echo "VM Launched - Waiting for run.sh" | 
|  | 395 | while ! ssh_no_check -q stack@$OS_VM_MANAGEMENT_ADDRESS "test -e /opt/stack/run_sh.pid"; do | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 396 | sleep 10 | 
| Anthony Young | 1de18c6 | 2011-11-01 14:19:18 -0500 | [diff] [blame] | 397 | done | 
| Bob Ball | d6b43a0 | 2014-07-14 15:18:33 +0100 | [diff] [blame] | 398 | echo -n "devstack service is running, waiting for stack.sh to start logging..." | 
|  | 399 |  | 
| Bob Ball | 0686dae | 2015-01-15 12:48:26 +0000 | [diff] [blame] | 400 | pid=`ssh_no_check -q stack@$OS_VM_MANAGEMENT_ADDRESS "cat /opt/stack/run_sh.pid"` | 
| Bob Ball | 1e3a5d2 | 2015-01-16 13:06:58 +0000 | [diff] [blame] | 401 | if [ -n "$SCREEN_LOGDIR" ]; then | 
|  | 402 | while ! ssh_no_check -q stack@$OS_VM_MANAGEMENT_ADDRESS "test -e ${SCREEN_LOGDIR}/stack.log"; do | 
|  | 403 | sleep 10 | 
|  | 404 | done | 
| Bob Ball | dc7ebbb | 2014-06-24 13:59:49 +0100 | [diff] [blame] | 405 |  | 
| Bob Ball | 1e3a5d2 | 2015-01-16 13:06:58 +0000 | [diff] [blame] | 406 | ssh_no_check -q stack@$OS_VM_MANAGEMENT_ADDRESS "tail --pid $pid -n +1 -f ${SCREEN_LOGDIR}/stack.log" | 
|  | 407 | else | 
|  | 408 | echo -n "SCREEN_LOGDIR not set; just waiting for process $pid to finish" | 
|  | 409 | ssh_no_check -q stack@$OS_VM_MANAGEMENT_ADDRESS "wait $pid" | 
|  | 410 | fi | 
|  | 411 |  | 
|  | 412 | set -x | 
| Mate Lakat | 93f3b86 | 2013-09-24 17:35:00 +0100 | [diff] [blame] | 413 | # Fail if devstack did not succeed | 
| Bob Ball | 0686dae | 2015-01-15 12:48:26 +0000 | [diff] [blame] | 414 | ssh_no_check -q stack@$OS_VM_MANAGEMENT_ADDRESS 'test -e /opt/stack/runsh.succeeded' | 
| Mate Lakat | 9efcf60 | 2012-12-19 10:23:06 +0000 | [diff] [blame] | 415 |  | 
| Bob Ball | 63c6c2b | 2013-01-24 13:13:51 +0000 | [diff] [blame] | 416 | set +x | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 417 | echo "################################################################################" | 
| Anthony Young | 1de18c6 | 2011-11-01 14:19:18 -0500 | [diff] [blame] | 418 | echo "" | 
| John Garbutt | daadf74 | 2012-04-27 18:28:28 +0100 | [diff] [blame] | 419 | echo "All Finished!" | 
|  | 420 | echo "You can visit the OpenStack Dashboard" | 
| Mate Lakat | 8644676 | 2013-05-12 18:34:29 +0100 | [diff] [blame] | 421 | echo "at http://$OS_VM_SERVICES_ADDRESS, and contact other services at the usual ports." | 
| Anthony Young | 1de18c6 | 2011-11-01 14:19:18 -0500 | [diff] [blame] | 422 | else | 
| Bob Ball | 63c6c2b | 2013-01-24 13:13:51 +0000 | [diff] [blame] | 423 | set +x | 
| Anthony Young | 1de18c6 | 2011-11-01 14:19:18 -0500 | [diff] [blame] | 424 | echo "################################################################################" | 
|  | 425 | echo "" | 
|  | 426 | echo "All Finished!" | 
|  | 427 | echo "Now, you can monitor the progress of the stack.sh installation by " | 
| Mate Lakat | 93f3b86 | 2013-09-24 17:35:00 +0100 | [diff] [blame] | 428 | echo "looking at the console of your domU / checking the log files." | 
| Anthony Young | 1de18c6 | 2011-11-01 14:19:18 -0500 | [diff] [blame] | 429 | echo "" | 
| Mate Lakat | 8644676 | 2013-05-12 18:34:29 +0100 | [diff] [blame] | 430 | echo "ssh into your domU now: 'ssh stack@$OS_VM_MANAGEMENT_ADDRESS' using your password" | 
| Mate Lakat | 93f3b86 | 2013-09-24 17:35:00 +0100 | [diff] [blame] | 431 | echo "and then do: 'sudo service devstack status' to check if devstack is still running." | 
| Bob Ball | 0686dae | 2015-01-15 12:48:26 +0000 | [diff] [blame] | 432 | echo "Check that /opt/stack/runsh.succeeded exists" | 
| Anthony Young | 1de18c6 | 2011-11-01 14:19:18 -0500 | [diff] [blame] | 433 | echo "" | 
| Mate Lakat | 93f3b86 | 2013-09-24 17:35:00 +0100 | [diff] [blame] | 434 | echo "When devstack completes, you can visit the OpenStack Dashboard" | 
| Mate Lakat | 8644676 | 2013-05-12 18:34:29 +0100 | [diff] [blame] | 435 | echo "at http://$OS_VM_SERVICES_ADDRESS, and contact other services at the usual ports." | 
| Anthony Young | 1de18c6 | 2011-11-01 14:19:18 -0500 | [diff] [blame] | 436 | fi |