
This patch renames a few libraries whose names don't match *.sh. This allows tox to easily find all bash libraries and check them with bashate. Change-Id: Icf231dacc3fa78d20f1b48a4befb917a1d15dd3d
156 lines
4.9 KiB
Bash
Executable File
156 lines
4.9 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
set -o errexit -o nounset
|
|
TOP_DIR=$(cd "$(dirname "$0")/.." && pwd)
|
|
source "$TOP_DIR/config/paths"
|
|
source "$CONFIG_DIR/credentials"
|
|
source "$LIB_DIR/functions.guest.sh"
|
|
exec_logfile
|
|
|
|
indicate_current_auto
|
|
|
|
#------------------------------------------------------------------------------
|
|
# Install the Image Service (glance).
|
|
# http://docs.openstack.org/kilo/install-guide/install/apt/content/glance-install.html
|
|
#------------------------------------------------------------------------------
|
|
|
|
echo "Setting up database for glance."
|
|
setup_database glance
|
|
|
|
echo "Sourcing the admin credentials."
|
|
source "$CONFIG_DIR/admin-openstackrc.sh"
|
|
|
|
glance_admin_user=$(service_to_user_name glance)
|
|
glance_admin_password=$(service_to_user_password glance)
|
|
|
|
# Wait for keystone to come up
|
|
wait_for_keystone
|
|
|
|
echo "Creating glance user and giving it admin role under service tenant."
|
|
openstack user create \
|
|
--password "$glance_admin_password" \
|
|
"$glance_admin_user"
|
|
|
|
openstack role add \
|
|
--project "$SERVICE_PROJECT_NAME" \
|
|
--user "$glance_admin_user" \
|
|
"$ADMIN_ROLE_NAME"
|
|
|
|
echo "Registering glance with keystone so that other services can locate it."
|
|
openstack service create \
|
|
--name glance \
|
|
--description "OpenStack Image Service" \
|
|
image
|
|
|
|
openstack endpoint create \
|
|
--publicurl "http://controller-api:9292" \
|
|
--internalurl "http://controller-mgmt:9292" \
|
|
--adminurl "http://controller-mgmt:9292" \
|
|
--region "$REGION" \
|
|
image
|
|
|
|
echo "Installing glance."
|
|
sudo apt-get install -y glance python-glanceclient
|
|
|
|
function get_database_url {
|
|
local db_user=$(service_to_db_user glance)
|
|
local db_password=$(service_to_db_password glance)
|
|
local database_host=controller-mgmt
|
|
|
|
echo "mysql://$db_user:$db_password@$database_host/glance"
|
|
}
|
|
|
|
database_url=$(get_database_url)
|
|
echo "Database connection: $database_url."
|
|
|
|
echo "Configuring glance-api.conf."
|
|
conf=/etc/glance/glance-api.conf
|
|
|
|
# Database
|
|
iniset_sudo $conf database connection "$database_url"
|
|
|
|
# Keystone_authtoken
|
|
iniset_sudo $conf keystone_authtoken auth_uri http://controller-mgmt:5000
|
|
iniset_sudo $conf keystone_authtoken auth_url http://controller-mgmt:35357
|
|
iniset_sudo $conf keystone_authtoken auth_plugin password
|
|
iniset_sudo $conf keystone_authtoken project_domain_id default
|
|
iniset_sudo $conf keystone_authtoken user_domain_id default
|
|
iniset_sudo $conf keystone_authtoken project_name "$SERVICE_PROJECT_NAME"
|
|
iniset_sudo $conf keystone_authtoken username "$glance_admin_user"
|
|
iniset_sudo $conf keystone_authtoken password "$glance_admin_password"
|
|
|
|
# Paste_deploy
|
|
iniset_sudo $conf paste_deploy flavor "keystone"
|
|
|
|
# Glance_store
|
|
iniset_sudo $conf glance_store default_store file
|
|
iniset_sudo $conf glance_store filesystem_store_datadir /var/lib/glance/images/
|
|
|
|
# Default section
|
|
iniset_sudo $conf DEFAULT notification_driver noop
|
|
iniset_sudo $conf DEFAULT verbose True
|
|
|
|
echo "Configuring glance-registry.conf."
|
|
conf=/etc/glance/glance-registry.conf
|
|
|
|
# Database section
|
|
iniset_sudo $conf database connection "$database_url"
|
|
|
|
# Keystone authtoken section
|
|
iniset_sudo $conf keystone_authtoken auth_uri http://controller-mgmt:5000
|
|
iniset_sudo $conf keystone_authtoken auth_url http://controller-mgmt:35357
|
|
iniset_sudo $conf keystone_authtoken auth_plugin password
|
|
iniset_sudo $conf keystone_authtoken project_domain_id default
|
|
iniset_sudo $conf keystone_authtoken user_domain_id default
|
|
iniset_sudo $conf keystone_authtoken project_name "$SERVICE_PROJECT_NAME"
|
|
iniset_sudo $conf keystone_authtoken username "$glance_admin_user"
|
|
iniset_sudo $conf keystone_authtoken password "$glance_admin_password"
|
|
|
|
# Glance store
|
|
iniset_sudo $conf glance_store default_store file
|
|
iniset_sudo $conf glance_store filesystem_store_datadir /var/lib/glance/images/
|
|
|
|
# Paste deploy section
|
|
iniset_sudo $conf paste_deploy flavor "keystone"
|
|
|
|
# Default section
|
|
iniset_sudo $conf DEFAULT notification_driver noop
|
|
iniset_sudo $conf DEFAULT verbose True
|
|
|
|
echo "Creating the database tables for glance."
|
|
sudo glance-manage db_sync
|
|
|
|
echo "Restarting glance service."
|
|
sudo service glance-registry restart
|
|
sudo service glance-api restart
|
|
|
|
echo "Removing default SQLite database."
|
|
sudo rm -f /var/lib/glance/glance.sqlite
|
|
|
|
#------------------------------------------------------------------------------
|
|
# Verify the Image Service installation
|
|
# http://docs.openstack.org/kilo/install-guide/install/apt/content/glance-verify.html
|
|
#------------------------------------------------------------------------------
|
|
|
|
echo "Waiting for glance to start."
|
|
until glance image-list >/dev/null 2>&1; do
|
|
sleep 1
|
|
done
|
|
|
|
# cirros-0.3.3-x86_64-disk.img -> cirros-0.3.3-x86_64
|
|
img_name=$(basename $CIRROS_URL -disk.img)
|
|
|
|
echo "Adding CirrOS image as $img_name to glance."
|
|
|
|
glance image-create \
|
|
--name "$img_name" \
|
|
--file "$HOME/img/$(basename $CIRROS_URL)" \
|
|
--disk-format qcow2 \
|
|
--container-format bare \
|
|
--visibility public \
|
|
--progress
|
|
|
|
echo "Verifying that the image was successfully added to the service."
|
|
|
|
echo "glance image-list"
|
|
glance image-list
|