summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorQiLiang <liangqi1@huawei.com>2015-12-24 08:48:00 +0000
committerQiLiang <liangqi1@huawei.com>2015-12-24 08:48:00 +0000
commit2f21668968622e358c93f1a743acc6562d15866a (patch)
tree335a3b74dea9fa64faa23776c691893e008732c2
parenta36dd89dce8b4c3fd4e9dba6009b3b6cc7deb3ad (diff)
Update heat stack creation script
JIRA: BOTTLENECK-35 Change-Id: Ie74c1f313a5b3f987171442d1c5b453ad7d8eec8 Signed-off-by: QiLiang <liangqi1@huawei.com>
-rwxr-xr-xutils/infra_setup/heat_template/HOT_create_instance.sh97
1 files changed, 43 insertions, 54 deletions
diff --git a/utils/infra_setup/heat_template/HOT_create_instance.sh b/utils/infra_setup/heat_template/HOT_create_instance.sh
index 9d80022d..f04198c8 100755
--- a/utils/infra_setup/heat_template/HOT_create_instance.sh
+++ b/utils/infra_setup/heat_template/HOT_create_instance.sh
@@ -21,24 +21,38 @@ bottlenecks_create_instance()
echo "upload keypair"
nova keypair-add --pub_key $KEY_PATH/bottlenecks_key.pub $KEY_NAME
- #need FIX, only upload the public key? should be keypair
+
+ echo "create flavor"
+ nova flavor-create $FLAVOR_NAME 200 2048 10 1
echo "use heat template to create stack"
cd $HOT_PATH
- heat stack-create bottlenecks -f ${TEMPLATE_NAME} -P "image=$IMAGE_NAME;key=$KEY_NAME;public_network=$PUBLIC_NET_NAME"
- sleep 60
+ heat stack-create bottlenecks -f ${TEMPLATE_NAME} \
+ -P "image=$IMAGE_NAME;key_name=$KEY_NAME;public_net=$PUBLIC_NET_NAME;flavor=$FLAVOR_NAME"
+ sleep 120
heat stack-list
heat stack-show bottlenecks
nova list
+ nova list | grep rubbos_control
+ control_ip=$(nova list | grep rubbos_control | awk '{print $13}')
+ ssh -i $KEY_PATH/bottlenecks_key \
+ -o StrictHostKeyChecking=no \
+ -o BatchMode=yes root@$control_ip "uname -a"
heat stack-delete bottlenecks
-
- #need FIX, use stack to create 9 VMs
}
bottlenecks_cleanup()
{
echo "clean up bottlenecks images and keys"
+ if heat stack-list; then
+ for stack in $(heat stack-list | grep -e bottlenecks | awk '{print $2}'); do
+ echo "clean up stack $stack"
+ heat stack-delete $stack || true
+ sleep 30
+ done
+ fi
+
if glance image-list; then
for image in $(glance image-list | grep -e $IMAGE_NAME | awk '{print $2}'); do
echo "clean up image $image"
@@ -49,63 +63,40 @@ bottlenecks_cleanup()
if nova keypair-list; then
for key in $(nova keypair-list | grep -e $KEY_NAME | awk '{print $2}'); do
echo "clean up key $key"
- nova keypair-delete || true
+ nova keypair-delete $key || true
done
fi
-}
-bottlenecks_build_image()
-{
- echo "build bottlenecks image"
-
- #need FIX
+ if nova flavor-list; then
+ for flavor in $(nova flavor-list | grep -e $FLAVOR_NAME | awk '{print $2}'); do
+ echo "clean up flavor $flavor"
+ nova flavor-delete $flavor || true
+ done
+ fi
}
-bottlenecks_load_cirros_image()
+bottlenecks_load_bottlenecks_image()
{
- echo "load bottlenecks cirros image"
+ echo "load bottlenecks image"
- wget http://download.cirros-cloud.net/0.3.3/cirros-0.3.3-x86_64-disk.img -O /tmp/cirros.img
+ wget $IMAGE_URL -O /tmp/bottlenecks-trusty-server.img
result=$(glance image-create \
- --name cirros-0.3.3 \
+ --name $IMAGE_NAME \
--disk-format qcow2 \
--container-format bare \
- --file /tmp/cirros.img)
+ --file /tmp/bottlenecks-trusty-server.img)
echo "$result"
- rm -rf /tmp/cirros.img
+ rm -rf /tmp/bottlenecks-trusty-server.img
- IMAGE_ID_CIRROS=$(echo "$result" | grep " id " | awk '{print $(NF-1)}')
- if [ -z "$IMAGE_ID_CIRROS" ]; then
- echo 'failed to upload cirros image to openstack'
+ IMAGE_ID_BOTTLENECKS=$(echo "$result" | grep " id " | awk '{print $(NF-1)}')
+ if [ -z "$IMAGE_ID_BOTTLENECKS" ]; then
+ echo 'failed to upload bottlenecks image to openstack'
exit 1
fi
- echo "cirros image id: $IMAGE_ID_CIRROS"
-}
-
-bottlenecks_load_image()
-{
- echo "load bottlenecks image"
-
- result=$(glance --os-image-api-version 1 image-create \
- --name $IMAGE_NAME \
- --is-public true --disk-format qcow2 \
- --container-format bare \
- --file $IMAGE_FILE_NAME)
- echo "$result"
-
- GLANCE_IMAGE_ID=$(echo "$result" | grep " id " | awk '{print $(NF-1)}')
-
- if [ -z "$GLANCE_IMAGE_ID" ]; then
- echo 'add image to glance failed'
- exit 1
- fi
-
- sudo rm -f $IMAGE_FILE_NAME
-
- echo "add glance image completed: $GLANCE_IMAGE_ID"
+ echo "bottlenecks image id: $IMAGE_ID_BOTTLENECKS"
}
main()
@@ -114,22 +105,20 @@ main()
BOTTLENECKS_REPO=https://gerrit.opnfv.org/gerrit/bottlenecks
BOTTLENECKS_REPO_DIR=/tmp/opnfvrepo/bottlenecks
- #IMAGE_URL=http://205.177.226.235:9999
- IMAGE_NAME=cirros-0.3.3
- #need FIX, need a script to transfer the image from the url to be the installer images
+ IMAGE_URL=http://205.177.226.235:9999/bottlenecks/rubbos/bottlenecks-trusty-server.img
+ IMAGE_NAME=bottlenecks-trusty-server
KEY_PATH=$BOTTLENECKS_REPO_DIR/utils/infra_setup/bottlenecks_key
HOT_PATH=$BOTTLENECKS_REPO_DIR/utils/infra_setup/heat_template
- KEY_NAME=bottlenecks_key
- TEMPLATE_NAME=bottlenecks_template1.yaml
+ KEY_NAME=bottlenecks-key
+ FLAVOR_NAME=bottlenecks-flavor
+ TEMPLATE_NAME=bottlenecks_rubbos_hot.yaml
PUBLIC_NET_NAME=net04_ext
- #need FIX
- #IMAGE_FILE_NAME=""
bottlenecks_env_prepare
bottlenecks_cleanup
- #bottlenecks_build_image
- bottlenecks_load_cirros_image
+ bottlenecks_load_bottlenecks_image
bottlenecks_create_instance
+ bottlenecks_cleanup
}
main