Update init-runonce to use openstack commands
Change-Id: I522feee353a7afcdca6862ce4e262e14e36df3a2
This commit is contained in:
parent
40e443da57
commit
f4b5c2db74
@ -11,12 +11,12 @@ unset LANG
|
|||||||
unset LANGUAGE
|
unset LANGUAGE
|
||||||
LC_ALL=C
|
LC_ALL=C
|
||||||
export LC_ALL
|
export LC_ALL
|
||||||
for i in curl nova neutron openstack; do
|
for i in curl openstack; do
|
||||||
if [[ ! $(type $i 2>/dev/null) ]]; then
|
if [[ ! $(type $i 2>/dev/null) ]]; then
|
||||||
if [ "$i" == 'curl' ]; then
|
if [ "$i" == 'curl' ]; then
|
||||||
echo "$i not installed. Please install $i before proceeding"
|
echo "Please install $i before proceeding"
|
||||||
else
|
else
|
||||||
echo "python-${i}client not installed. Please install python-${i}client before proceeding"
|
echo "Please install python-${i}client before proceeding"
|
||||||
fi
|
fi
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
@ -32,7 +32,7 @@ if [[ "${OS_USERNAME}" == "" ]]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Test to ensure configure script is run only once
|
# Test to ensure configure script is run only once
|
||||||
if glance image-list | grep -q cirros; then
|
if openstack image list | grep -q cirros; then
|
||||||
echo "This tool should only be run once per deployment."
|
echo "This tool should only be run once per deployment."
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
@ -44,23 +44,34 @@ if ! [ -f "$IMAGE" ]; then
|
|||||||
curl -L -o ./$IMAGE $IMAGE_URL/$IMAGE
|
curl -L -o ./$IMAGE $IMAGE_URL/$IMAGE
|
||||||
fi
|
fi
|
||||||
echo Creating glance image.
|
echo Creating glance image.
|
||||||
glance image-create --name cirros --progress --disk-format qcow2 --container-format bare --visibility public --progress --file ./$IMAGE
|
openstack image create --disk-format qcow2 --container-format bare --public \
|
||||||
|
--file ./$IMAGE cirros
|
||||||
|
|
||||||
echo Configuring neutron.
|
echo Configuring neutron.
|
||||||
neutron net-create public1 --router:external --provider:physical_network physnet1 --provider:network_type flat
|
openstack network create --external --provider-physical-network physnet1 \
|
||||||
neutron subnet-create --name 1-subnet --disable-dhcp --allocation-pool start=10.0.2.150,end=10.0.2.199 public1 10.0.2.0/24 --gateway 10.0.2.1
|
--provider-network-type flat public1
|
||||||
neutron net-create demo-net --provider:network_type vxlan
|
openstack subnet create --no-dhcp \
|
||||||
neutron subnet-create demo-net 10.0.0.0/24 --name demo-subnet --gateway 10.0.0.1 --dns-nameservers list=true 8.8.8.8
|
--allocation-pool start=10.0.2.150,end=10.0.2.199 --network public1 \
|
||||||
neutron router-create demo-router
|
--subnet-range 10.0.2.0/24 --gateway 10.0.2.1 1-subnet
|
||||||
neutron router-interface-add demo-router demo-subnet
|
|
||||||
neutron router-gateway-set demo-router public1
|
openstack network create --provider-network-type vxlan demo-net
|
||||||
|
openstack subnet create --subnet-range 10.0.0.0/24 --network demo-net \
|
||||||
|
--gateway 10.0.0.1 --dns-nameserver 8.8.8.8 demo-subnet
|
||||||
|
|
||||||
|
openstack router create demo-router
|
||||||
|
openstack router add subnet demo-router demo-subnet
|
||||||
|
openstack router set --external-gateway public1 demo-router
|
||||||
|
|
||||||
# Sec Group Config
|
# Sec Group Config
|
||||||
neutron security-group-rule-create default --direction ingress --ethertype IPv4 --protocol icmp --remote-ip-prefix 0.0.0.0/0
|
openstack security group rule create --ingress --ethertype IPv4 \
|
||||||
neutron security-group-rule-create default --direction ingress --ethertype IPv4 --protocol tcp --port-range-min 22 --port-range-max 22 --remote-ip-prefix 0.0.0.0/0
|
--protocol icmp default
|
||||||
|
openstack security group rule create --ingress --ethertype IPv4 \
|
||||||
|
--protocol tcp --dst-port 22 default
|
||||||
# Open heat-cfn so it can run on a different host
|
# Open heat-cfn so it can run on a different host
|
||||||
neutron security-group-rule-create default --direction ingress --ethertype IPv4 --protocol tcp --port-range-min 8000 --port-range-max 8000 --remote-ip-prefix 0.0.0.0/0
|
openstack security group rule create --ingress --ethertype IPv4 \
|
||||||
neutron security-group-rule-create default --direction ingress --ethertype IPv4 --protocol tcp --port-range-min 8080 --port-range-max 8080 --remote-ip-prefix 0.0.0.0/0
|
--protocol tcp --dst-port 8000 default
|
||||||
|
openstack security group rule create --ingress --ethertype IPv4 \
|
||||||
|
--protocol tcp --dst-port 8080 default
|
||||||
|
|
||||||
if [ ! -f ~/.ssh/id_rsa.pub ]; then
|
if [ ! -f ~/.ssh/id_rsa.pub ]; then
|
||||||
echo Generating ssh key.
|
echo Generating ssh key.
|
||||||
@ -68,7 +79,7 @@ if [ ! -f ~/.ssh/id_rsa.pub ]; then
|
|||||||
fi
|
fi
|
||||||
if [ -r ~/.ssh/id_rsa.pub ]; then
|
if [ -r ~/.ssh/id_rsa.pub ]; then
|
||||||
echo Configuring nova public key and quotas.
|
echo Configuring nova public key and quotas.
|
||||||
nova keypair-add --pub-key ~/.ssh/id_rsa.pub mykey
|
openstack keypair create --public-key ~/.ssh/id_rsa.pub mykey
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Increase the quota to allow 40 m1.small instances to be created
|
# Increase the quota to allow 40 m1.small instances to be created
|
||||||
@ -78,16 +89,13 @@ ADMIN_USER_ID=$(openstack user list | awk '/ admin / {print $2}')
|
|||||||
ADMIN_PROJECT_ID=$(openstack project list | awk '/ admin / {print $2}')
|
ADMIN_PROJECT_ID=$(openstack project list | awk '/ admin / {print $2}')
|
||||||
|
|
||||||
# 40 instances
|
# 40 instances
|
||||||
nova quota-update --instances 40 $ADMIN_PROJECT_ID
|
openstack quota set --instances 40 $ADMIN_PROJECT_ID
|
||||||
nova quota-update --user $ADMIN_USER_ID --instances 40 $ADMIN_PROJECT_ID
|
|
||||||
|
|
||||||
# 40 cores
|
# 40 cores
|
||||||
nova quota-update --cores 40 $ADMIN_PROJECT_ID
|
openstack quota set --cores 40 $ADMIN_PROJECT_ID
|
||||||
nova quota-update --user $ADMIN_USER_ID --cores 40 $ADMIN_PROJECT_ID
|
|
||||||
|
|
||||||
# 96GB ram
|
# 96GB ram
|
||||||
nova quota-update --ram 96000 $ADMIN_PROJECT_ID
|
openstack quota set --ram 96000 $ADMIN_PROJECT_ID
|
||||||
nova quota-update --user $ADMIN_USER_ID --ram 96000 $ADMIN_PROJECT_ID
|
|
||||||
|
|
||||||
# add default flavors, if they don't already exist
|
# add default flavors, if they don't already exist
|
||||||
if ! openstack flavor list | grep -q m1.tiny; then
|
if ! openstack flavor list | grep -q m1.tiny; then
|
||||||
|
Loading…
Reference in New Issue
Block a user