lib.sh: Use host-passthrough when spawning VMs
[fuel.git] / mcp / scripts / lib.sh
1 #
2 # Library of shell functions
3 #
4
5 generate_ssh_key() {
6   local user=${SUDO_USER:-$USER}
7
8   [ -f "$SSH_KEY" ] || ssh-keygen -f ${SSH_KEY} -N ''
9   install -o $user -m 0600 ${SSH_KEY} /tmp/
10 }
11
12 get_base_image() {
13   local base_image=$1
14
15   mkdir -p images
16   wget -P /tmp -nc $base_image
17 }
18
19 cleanup_vms() {
20   # clean up existing nodes
21   for node in $(virsh list --name | grep -P '\w{3}\d{2}'); do
22     virsh destroy $node
23   done
24   for node in $(virsh list --name --all | grep -P '\w{3}\d{2}'); do
25     virsh undefine --nvram $node
26   done
27 }
28
29 prepare_vms() {
30   local -n vnodes=$1
31   local base_image=$2
32
33   cleanup_vms
34   get_base_image $base_image
35   envsubst < user-data.template > user-data.sh
36
37   for node in "${vnodes[@]}"; do
38     # create/prepare images
39     ./create-config-drive.sh -k ${SSH_KEY}.pub -u user-data.sh -h ${node} images/mcp_${node}.iso
40     cp /tmp/${base_image/*\/} images/mcp_${node}.qcow2
41     qemu-img resize images/mcp_${node}.qcow2 100G
42   done
43 }
44
45 create_networks() {
46   # create required networks
47   for net in pxe mgmt internal public; do
48     if virsh net-info $net >/dev/null 2>&1; then
49       virsh net-destroy ${net}
50       virsh net-undefine ${net}
51     fi
52     virsh net-define net_${net}.xml
53     virsh net-autostart ${net}
54     virsh net-start ${net}
55   done
56 }
57
58 create_vms() {
59   local -n vnodes=$1
60   local -n vnodes_ram=$2
61   local -n vnodes_vcpus=$3
62
63   # create vms with specified options
64   for node in "${vnodes[@]}"; do
65     virt-install --name ${node} \
66     --ram ${vnodes_ram[$node]} --vcpus ${vnodes_vcpus[$node]} \
67     --cpu host-passthrough --accelerate \
68     --network network:pxe,model=virtio \
69     --network network:mgmt,model=virtio \
70     --network network:internal,model=virtio \
71     --network network:public,model=virtio \
72     --disk path=$(pwd)/images/mcp_${node}.qcow2,format=qcow2,bus=virtio,cache=none,io=native \
73     --os-type linux --os-variant none \
74     --boot hd --vnc --console pty --autostart --noreboot \
75     --disk path=$(pwd)/images/mcp_${node}.iso,device=cdrom \
76     --noautoconsole
77   done
78 }
79
80 update_pxe_network() {
81   # set static ip address for salt master node
82   virsh net-update pxe add ip-dhcp-host \
83   "<host mac='$(virsh domiflist cfg01 | awk '/pxe/ {print $5}')' name='cfg01' ip='$SALT_MASTER'/>" --live
84 }
85
86 start_vms() {
87   local -n vnodes=$1
88
89   # start vms
90   for node in "${vnodes[@]}"; do
91     virsh start ${node}
92     sleep $[RANDOM%5+1]
93   done
94 }
95
96 check_connection() {
97   local total_attempts=60
98   local sleep_time=5
99   local attempt=1
100
101   set +e
102   echo '[INFO] Attempting to get into Salt master ...'
103
104   # wait until ssh on Salt master is available
105   while (($attempt <= $total_attempts)); do
106     ssh ${SSH_OPTS} ubuntu@${SALT_MASTER} uptime
107     case $? in
108       0) echo "${attempt}> Success"; break ;;
109       *) echo "${attempt}/${total_attempts}> ssh server ain't ready yet, waiting for ${sleep_time} seconds ..." ;;
110     esac
111     sleep $sleep_time
112     ((attempt+=1))
113   done
114   set -e
115 }
116
117 parse_yaml() {
118   local prefix=$2
119   local s
120   local w
121   local fs
122   s='[[:space:]]*'
123   w='[a-zA-Z0-9_]*'
124   fs="$(echo @|tr @ '\034')"
125   sed -ne "s|^\($s\)\($w\)$s:$s\"\(.*\)\"$s\$|\1$fs\2$fs\3|p" \
126       -e "s|^\($s\)\($w\)$s[:-]$s\(.*\)$s\$|\1$fs\2$fs\3|p" "$1" |
127   awk -F"$fs" '{
128   indent = length($1)/2;
129   vname[indent] = $2;
130   for (i in vname) {if (i > indent) {delete vname[i]}}
131       if (length($3) > 0) {
132           vn=""; for (i=0; i<indent; i++) {vn=(vn)(vname[i])("_")}
133           printf("%s%s%s=(\"%s\")\n", "'"$prefix"'",vn, $2, $3);
134       }
135   }' | sed 's/_=/+=/g'
136 }