blob: 78341b2b0d74be12cbfa4d9610084f0806297913 [file] [log] [blame]
Alexa4437742022-02-16 14:42:38 -06001#!/bin/bash
2export OS_INTERFACE='admin'
3
4# local vars
5name_prefix=cvp
6filename=${name_prefix}.manifest
7rcfile=${name_prefix}rc
8huge_pages=false
9logfile=prepare.log
10
11# Project, User, Roles
12project=${name_prefix}.project
13user=${name_prefix}.user
14admin=${name_prefix}.admin
15password=mcp1234
16
17# Security group
18sg_all=${name_prefix}.sg.all
19sg_icmp=${name_prefix}.sg.icmp
20sg_ssh=${name_prefix}.sg.ssh
21sg_iperf=${name_prefix}.sg.perf
22
23# Testkey
24key=${name_prefix}_testkey
25
26# Flavors: tiny, small (cirrus and migration), medium (ubuntu and volume/stress activities)
27flavor_t=${name_prefix}.tiny
28flavor_s=${name_prefix}.small
29flavor_m=${name_prefix}.medium
30flavor_h=${name_prefix}.high
31
32# Fixed Networks (2, for testing router interconnection)
33net_left=${name_prefix}.net.1
34net_right=${name_prefix}.net.2
35subnet1=${name_prefix}.subnet.1
36subnet2=${name_prefix}.subnet.2
37
38# Router
39router=${name_prefix}.router
40
41# Images: cirros (3.5, 4.0), ubuntu (16.04)
Alexdb7786b2022-02-21 17:58:29 -060042cirros51=${name_prefix}.cirros.51
43cirros52=${name_prefix}.cirros.52
Alexa4437742022-02-16 14:42:38 -060044ubuntu16=${name_prefix}.ubuntu.1604
Alexdb7786b2022-02-21 17:58:29 -060045ubuntu20=${name_prefix}.ubuntu.2004
Alexa4437742022-02-16 14:42:38 -060046
Alexdb7786b2022-02-21 17:58:29 -060047#cirros3_link=http://download.cirros-cloud.net/0.3.5/cirros-0.3.5-x86_64-disk.img
48#cirros4_link=http://download.cirros-cloud.net/0.4.0/cirros-0.4.0-aarch64-disk.img
49cirros51_link=https://download.cirros-cloud.net/0.5.1/cirros-0.5.1-x86_64-disk.img
50cirros52_link=https://download.cirros-cloud.net/0.5.2/cirros-0.5.2-x86_64-disk.img
Alexa4437742022-02-16 14:42:38 -060051ubuntu16_link=https://cloud-images.ubuntu.com/xenial/current/xenial-server-cloudimg-amd64-disk1.img
Alexdb7786b2022-02-21 17:58:29 -060052ubuntu20_link=https://cloud-images.ubuntu.com/focal/current/focal-server-cloudimg-amd64.img
Alexa4437742022-02-16 14:42:38 -060053
54# Volume (2GB)
55volume=${name_prefix}.volume
56
57function show_help {
58 printf "CVP Pipeline: Resource creation script\n\t-h, -?\t\tShow this help\n"
59 printf "\t-H\t\tAdds '--property hw:mem_page_size=large' to flavors, i.e. huge_pages for DPDK\n"
60 printf "\t-w <path>\tSets working folder"
61}
62
63OPTIND=1 # Reset in case getopts has been used previously in the shell.
64while getopts "h?:Hw:" opt; do
65 case "$opt" in
66 h|\?)
67 show_help
68 exit 0
69 ;;
70 w) working_folder=${OPTARG}
71 printf "# Working folder is ${working_folder}\n"
72 ;;
73 h) huge_pages=true
74 printf "# Using 'huge_pages' property in flavors\n"
75 ;;
76 esac
77done
78
79shift $((OPTIND-1))
80[ "${1:-}" = "--" ] && shift
81
82function put() {
83 echo "$1=$2" | tee -a ${filename}
84}
85
86# now, some hard to understand stuff...
87# f1 $(<command with output to cut>)
88function f1() { echo $1 | cut -d' ' -f1; };
89# <commands with output to cut> | p1
90function p1() { while read input; do echo ${input} | cut -d' ' -f1; done; };
91# ol1 is short for openstack list with 1 param. Also grep and cut
92# "ol1 network public" will list all networks, grep by name public and return IDs
93function ol1() { echo $(openstack $1 list -c ID -c Name -f value | grep $2 | cut -d' ' -f1); }
94# same as ol1 but with 2 initial commands before list
95function ol2() { echo $(openstack $1 $2 list -c ID -c Name -f value | grep $3 | cut -d' ' -f1); }
96
97function print_manifest() {
98 touch ./${filename}
99 truncate -s 0 ${filename}
100 printf "\n\n# Checking and filling manifest: $(pwd)/${filename}\n"
101 put project_name ${project}
102 put project_id $(ol1 project ${project})
103 put user_name ${user}
104 put user_id $(ol1 user ${user})
105 put admin_name ${admin}
106 put admin_id $(ol1 user ${admin})
107 # sg
108 put secgroup_all_name ${sg_all}
109 put secgroup_all_id $(ol2 security group ${sg_all})
110 put secgroup_icmp_name ${sg_icmp}
111 put secgroup_icmp_id $(ol2 security group ${sg_icmp})
112 put secgroup_ssh_name ${sg_ssh}
113 put secgroup_ssh_id $(ol2 security group ${sg_ssh})
114 put secgroup_iperf_name ${sg_iperf}
115 put secgroup_iperf_id $(ol2 security group ${sg_iperf})
116
117 # keypair
118 put keypair_name ${key}
119 put keypair_id $(ol1 keypair ${key})
120
121 # flavors
122 put flavor_tiny_name ${flavor_t}
123 put flavor_tiny_id $(ol1 flavor ${flavor_t})
124 put flavor_small_name ${flavor_s}
125 put flavor_small_id $(ol1 flavor ${flavor_s})
126 put flavor_medium_name ${flavor_m}
127 put flavor_medium_id $(ol1 flavor ${flavor_m})
128 put flavor_high_name ${flavor_h}
129 put flavor_high_id $(ol1 flavor ${flavor_h})
130
131 # fixed nets
132 put fixed_net_left_name ${net_left}
133 put fixed_net_left_id $(ol1 network ${net_left})
134 put fixed_net_right_name ${net_right}
135 put fixed_net_right_id $(ol1 network ${net_right})
136 put fixed_net_left_subnet_name ${subnet1}
137 put fixed_net_left_subnet_id $(openstack subnet list --network ${net_left} -c ID -f value | p1)
138 put fixed_net_right_subnet_name ${subnet2}
139 put fixed_net_right_subnet_id $(openstack subnet list --network ${net_right} -c ID -f value | p1)
140
141 # router
142 put router_name ${router}
143 put router_id $(ol1 router ${router})
144
145 # volumes
146 put volume_name ${volume}
147 put volume_id $(ol1 volume ${volume})
148
149 # images
Alexdb7786b2022-02-21 17:58:29 -0600150 put cirros51_name ${cirros51}
151 put cirros51_id $(ol1 image ${cirros51})
152 put cirros52_name ${cirros52}
153 put cirros52_id $(ol1 image ${cirros52})
Alexa4437742022-02-16 14:42:38 -0600154 put ubuntu16_name ${ubuntu16}
155 put ubuntu16_id $(ol1 image ${ubuntu16})
Alexdb7786b2022-02-21 17:58:29 -0600156 put ubuntu20_name ${ubuntu20}
157 put ubuntu20_id $(ol1 image ${ubuntu20})
Alexa4437742022-02-16 14:42:38 -0600158}
159
160# create rc file out of current ENV vars
161function putrc() {
162 printf "# Saving ${1} file\n"
163 echo "export OS_IDENTITY_API_VERSION=${OS_IDENTITY_API_VERSION:-3}" >${1}
164 echo "export OS_AUTH_URL=${OS_AUTH_URL}" >>${1}
165 echo "export OS_PROJECT_DOMAIN_NAME=${OS_PROJECT_DOMAIN_NAME}" >>${1}
166 echo "export OS_USER_DOMAIN_NAME=${OS_USER_DOMAIN_NAME}" >>${1}
167 echo "export OS_PROJECT_NAME=${OS_PROJECT_NAME}" >>${1}
168 echo "export OS_TENANT_NAME=${OS_TENANT_NAME}" >>${1}
169 echo "export OS_USERNAME=${OS_USERNAME}" >>${1}
170 echo "export OS_PASSWORD=${OS_PASSWORD}" >>${1}
171 echo "export OS_REGION_NAME=${OS_REGION_NAME}" >>${1}
172 echo "export OS_INTERFACE=${OS_INTERFACE}" >>${1}
173 echo "export OS_ENDPOINT_TYPE=${OS_ENDPOINT_TYPE}" >>${1}
174 echo "export OS_CACERT=${OS_CACERT}" >>${1}
175}
176
177# update ENV vars to newly created project
178function updatesession() {
179 export OS_PROJECT_NAME=${project}
180 export OS_TENANT_NAME=${project}
181 export OS_USERNAME=${admin}
182 export OS_PASSWORD=${password}
183}
184
185function process_cmds() {
186 if [ -s ${cmds} ]; then
187 cat ${cmds} | tr '\n' '\0' | xargs -P 1 -n 1 -0 echo | tee /dev/tty | openstack -v 2>&1 >>${logfile}
188 truncate -s 0 ${cmds}
189 fi
190}
191
192function _project() {
193 echo project create ${project} >>${cmds}
Ievgeniia Zadorozhnaa76c8522023-08-03 17:00:54 +0300194 admin_username=$(openstack user list --project admin -c Name -f value | grep admin)
195 echo role add --user ${admin_username} --project ${project} admin >>${cmds}
Alexa4437742022-02-16 14:42:38 -0600196}
197
198function _users() {
199 echo user create --project ${project} --password ${password} ${user} >>${cmds}
200 echo user create --project ${project} --password ${password} ${admin} >>${cmds}
201 echo role add --user ${admin} --project ${project} admin >>${cmds}
202 echo role add --user ${admin} --project ${project} creator >>${cmds}
203 echo role add --user ${user} --project ${project} member >>${cmds}
204 echo role add --user ${user} --project ${project} creator >>${cmds}
Ievgeniia Zadorozhna5452a372023-07-10 20:54:13 +0300205 echo role add --user ${user} --project ${project} load-balancer_member >>${cmds}
Alexa4437742022-02-16 14:42:38 -0600206
207}
208
209function _sg_all() {
210 echo security group create --project ${project} ${sg_all} >>${cmds}
211 # icmp
212 echo security group rule create --protocol icmp ${sg_all} >>${cmds}
213 # ssh
214 echo security group rule create --protocol tcp --dst-port 22 ${sg_all} >>${cmds}
215 # iperf
216 echo security group rule create --protocol tcp --dst-port 5001 ${sg_all} >>${cmds}
217 # iperf3
218 echo security group rule create --protocol tcp --dst-port 5201 ${sg_all} >>${cmds}
219 # nc connectivity
220 echo security group rule create --protocol tcp --dst-port 3000 ${sg_all} >>${cmds}
221 # http
222 echo security group rule create --protocol tcp --dst-port 80 ${sg_all} >>${cmds}
223 # https
224 echo security group rule create --protocol tcp --dst-port 443 ${sg_all} >>${cmds}
225}
226
227function _sg_icmp() {
228 echo security group create --project ${project} ${sg_icmp} >>${cmds}
229 echo security group rule create --protocol icmp ${sg_icmp} >>${cmds}
230}
231
232function _sg_ssh() {
233 echo security group create --project ${project} ${sg_ssh} >>${cmds}
234 # icmp
235 echo security group rule create --protocol icmp ${sg_ssh} >>${cmds}
236 # ssh
237 echo security group rule create --protocol tcp --dst-port 22 ${sg_ssh} >>${cmds}
238}
239
240function _sg_iperf() {
241 echo security group create --project ${project} ${sg_iperf} >>${cmds}
242 # icmp
243 echo security group rule create --protocol icmp ${sg_iperf} >>${cmds}
244 # iperf
245 echo security group rule create --protocol tcp --dst-port 5001 ${sg_iperf} >>${cmds}
246 # iperf3
247 echo security group rule create --protocol tcp --dst-port 5201 ${sg_iperf} >>${cmds}
248}
249
250function create_keypair() {
251 echo "# Creating keypair"
252 openstack keypair create ${key} >${key}
253 chmod 600 ${key}
254 echo "-> created keyfile: $(pwd)/${key}"
255}
256
257function _flavors() {
258 # huge paged flavors
259 if [ "$huge_pages" = true ]; then
Alexc7f187c2022-04-28 10:02:27 -0500260 echo flavor create --id 1 --ram 256 --disk 5 --vcpus 1 ${flavor_t} --property hw:mem_page_size=large >>${cmds}
261 echo flavor create --id 2 --ram 512 --disk 10 --vcpus 2 ${flavor_s} --property hw:mem_page_size=large >>${cmds}
262 echo flavor create --id 3 --ram 2048 --disk 20 --vcpus 4 ${flavor_m} --property hw:mem_page_size=large >>${cmds}
263 echo flavor create --id 4 --ram 4096 --disk 30 --vcpus 6 ${flavor_h} --property hw:mem_page_size=large >>${cmds}
Alexa4437742022-02-16 14:42:38 -0600264 else
Alexc7f187c2022-04-28 10:02:27 -0500265 echo flavor create --id 1 --ram 256 --disk 5 --vcpus 1 ${flavor_t} >>${cmds}
266 echo flavor create --id 2 --ram 512 --disk 10 --vcpus 2 ${flavor_s} >>${cmds}
267 echo flavor create --id 3 --ram 2048 --disk 20 --vcpus 4 ${flavor_m} >>${cmds}
268 echo flavor create --id 4 --ram 4096 --disk 30 --vcpus 6 ${flavor_h} >>${cmds}
Alexa4437742022-02-16 14:42:38 -0600269 fi
270}
271
272function _volumes() {
273 echo volume create --size 2 ${volume} >>${cmds}
274}
275
276function create_fixed_nets() {
277 echo "# Creating fixed networks"
278 echo network create --project ${project} ${net_left} >>${cmds}
279 echo subnet create ${subnet1} --network ${net_left} --subnet-range 10.10.11.0/24 >>${cmds}
280 echo network set --share ${net_left} >>${cmds}
281 echo network create --project ${project} ${net_right} >>${cmds}
282 echo subnet create ${subnet2} --network ${net_right} --subnet-range 10.10.12.0/24 >>${cmds}
283 echo network set --share ${net_right} >>${cmds}
284 process_cmds
285
286 # get subnet ids
287 subnet1_id=$(openstack subnet list --network ${net_left} -c ID -f value)
288 subnet2_id=$(openstack subnet list --network ${net_right} -c ID -f value)
289
290 echo router create --project ${project} ${router} >>${cmds}
291 process_cmds
292
293 router_id=$(openstack router list -c ID -c Name -f value | grep ${router} | cut -d' ' -f1)
294 echo router add subnet ${router_id} ${subnet1_id} >>${cmds}
295 echo router add subnet ${router_id} ${subnet2_id} >>${cmds}
296 process_cmds
297
Ievgeniia Zadorozhnadbf166a2022-03-09 18:52:36 +0300298 # get external network name
299 external=$(openstack network list --external -c Name -f value | head -n1)
Alexa4437742022-02-16 14:42:38 -0600300 echo router set ${router} --external-gateway ${external} >>${cmds}
301 process_cmds
302}
303
304function _get_image() {
305 # build vars for name and link
306 name="${1}"
307 link="${1}_link"
308 which wget >/dev/null
309 if [ $? -ne 0 ]; then
310 printf "\nERROR: 'wget' not detected. Download skipped: ${!name}\n"
311 else
312 # no redownloads, quet, save named and show progress
313 r=$(wget --no-check-certificate -nc -q -O ./${!name} --show-progress ${!link})
314 if [ $? -ne 0 ]; then
315 # non-empty output on error
316 echo ${r}
317 fi
318 fi
319}
320
321function create_image() {
322 name="${1}"
323 # Check if image is in the cloud
324 echo "# Checking image '${!name}'"
325 ids=( $(ol1 image ${!name}) )
326 # if array is empty, download and upload it
327 if [ ${#ids[@]} -eq 0 ]; then
328 # check and download
329 if [ ! -f ${!name} ]; then
330 r=$(_get_image ${1})
331 else
332 r=""
333 fi
334 # check if output is not empty
335 if [ ${#r} -eq 0 ]; then
336 image_id=$(openstack image create --public --disk-format qcow2 --container-format bare --file ${!name} ${!name} -c id -f value)
337 echo "-> created ${!name} (${image_id})"
338 else
339 printf "\n-> Error detected, creation skipped\n"
340 fi
341 else
342 # image(s) already there, list them
343 for id in ${ids[@]}; do
344 echo "-> found ${!name} with ID of '${id}'"
345 done
346 fi
347}
348
349###################
350### Main
351###################
352if [[ -z ${working_folder+x} ]]; then
353 # cwd into working dir
354 cd ${working_folder}
355fi
356
357cmds=$(mktemp)
358trap "rm -f ${cmds}" EXIT
359echo "Using tempfile: '${cmds}'"
360
361touch ${logfile}
362echo "Using log file: '${logfile}'"
363
364# Create
365echo "# Creating project and users"
366_project
367_users
368process_cmds
369
370echo "# Creating 'rc' and switching"
371putrc "./adminrc"
372updatesession
373putrc "./${rcfile}"
374
375echo "# Creating basic resources"
376# not dependent stuff
377_sg_all
378_sg_icmp
379_sg_ssh
380_sg_iperf
381_flavors
382_volumes
383process_cmds
384
385# sophisticated, step dependent stuff
386create_keypair
387create_fixed_nets
388
389# images
Alexdb7786b2022-02-21 17:58:29 -0600390create_image cirros51
391create_image cirros52
392create_image ubuntu16
393create_image ubuntu20
Alexa4437742022-02-16 14:42:38 -0600394
395### Manifest and fall back to original rc
396print_manifest
397printf ="\n\nSetting quota\n"
398openstack quota set --cores -1 --ram -1 --instances -1 --volumes -1 --gigabytes -1 cvp.project
399source "./adminrc"
400printf "\n\nOriginal rc preserved and backed up in 'adminrc'\nNew rc is '${rcfile}'\n"