forked from openstack-charmers/tf-ironic-lab
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathconfig-maas.sh
79 lines (61 loc) · 2.7 KB
/
config-maas.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
#!/bin/bash
#set -e
IMAGE_SERIES="bionic focal jammy"
PROFILE=admin
API_KEY_FILE=$HOME/admin-api-key
KVM_INTERNAL_IP=10.0.0.1
MAAS_INTERNAL_IP=10.0.0.2
INTERNAL_SUBNET=10.0.0.0/24
INFRA_RANGE_START=10.0.0.1
INFRA_RANGE_END=10.0.0.9
DHCP_RANGE_START=10.0.0.10
DHCP_RANGE_END=10.0.0.39
FIP_RANGE_START=10.0.0.40
FIP_RANGE_END=10.0.0.99
VIP_RANGE_START=10.0.0.100
VIP_RANGE_END=10.0.0.119
IMAGE_ARCH=amd64
maas login $PROFILE http://localhost:5240/MAAS - < $API_KEY_FILE >/dev/null
FABRIC_ID=$(maas $PROFILE subnet read $INTERNAL_SUBNET \
| grep fabric- -m 1 | awk '{print $2}' | cut -d '"' -f 2)
RACK_SYSTEM_ID=$(maas $PROFILE rack-controllers read \
| grep -i system_id -m 1 | cut -d '"' -f 4)
maas $PROFILE ipranges create type=reserved \
start_ip=$INFRA_RANGE_START end_ip=$INFRA_RANGE_END comment="Infra" \
>/dev/null && echo "Reserved IP range set (Infrastructure addresses)"
maas $PROFILE ipranges create type=dynamic \
start_ip=$DHCP_RANGE_START end_ip=$DHCP_RANGE_END \
>/dev/null && echo "Dynamic IP range set (DHCP for MAAS)"
maas $PROFILE ipranges create type=reserved \
start_ip=$FIP_RANGE_START end_ip=$FIP_RANGE_END comment="FIP for OpenStack" \
>/dev/null && echo "Reserved IP range set (FIP for OpenStack)"
maas $PROFILE ipranges create type=reserved \
start_ip=$VIP_RANGE_START end_ip=$VIP_RANGE_END comment="VIP for OpenStack" \
>/dev/null && echo "Reserved IP range set (VIP for OpenStack)"
maas $PROFILE vlan update $FABRIC_ID untagged \
dhcp_on=True primary_rack=$RACK_SYSTEM_ID \
>/dev/null && echo "DHCP enabled on untagged VLAN on $FABRIC_ID"
maas $PROFILE subnet update \
$INTERNAL_SUBNET gateway_ip=$KVM_INTERNAL_IP \
>/dev/null && echo "Default gateway set to $KVM_INTERNAL_IP for subnet $INTERNAL_SUBNET"
maas $PROFILE subnet update \
$INTERNAL_SUBNET dns_servers=$KVM_INTERNAL_IP \
>/dev/null && echo "DNS server set to $MAAS_INTERNAL_IP for subnet $INTERNAL_SUBNET"
maas $PROFILE maas set-config \
name=upstream_dns value=$KVM_INTERNAL_IP \
>/dev/null && echo "DNS forwarder set to $KVM_INTERNAL_IP"
maas $PROFILE maas set-config \
name=dnssec_validation value=no \
>/dev/null && echo "DNSSEC validation disabled"
# An image for the latest LTS release (first point release must be available)
# is selected by default (with the MAAS host's architecture).
# You may not need anything else.
# We're being explicit here.
for i in $IMAGE_SERIES; do
maas $PROFILE boot-source-selections create 1 \
os="ubuntu" release="$i" arches="$IMAGE_ARCH" subarches="*" labels="*" \
>/dev/null
done
# Initiate the import of images selected above.
maas $PROFILE boot-resources import \
>/dev/null && echo "Importing $IMAGE_SERIES amd64 images now..."