mogan/devstack/plugin.sh

265 lines
9.4 KiB
Bash

# ``stack.sh`` calls the entry points in this order:
#
# install_mogan
# install_python_moganclient
# configure_mogan
# start_mogan
# stop_mogan
# cleanup_mogan
# Save trace setting
XTRACE=$(set +o | grep xtrace)
set -o xtrace
# TODO(zhenguo): Remove this when placement is started as a separate service
if ! is_service_enabled placement; then
source $MOGAN_DIR/devstack/placement
fi
# Defaults
# --------
# create_mogan_accounts - Set up common required mogan accounts
#
# Project User Roles
# ------------------------------
# service mogan admin
function create_mogan_accounts {
create_service_user "mogan" "admin"
get_or_create_service "mogan" "baremetal_compute" "Baremetal Compute"
get_or_create_endpoint "baremetal_compute" \
"$REGION_NAME" \
"${MOGAN_SERVICE_PROTOCOL}://${MOGAN_SERVICE_HOST}/baremetal_compute/v1" \
"${MOGAN_SERVICE_PROTOCOL}://${MOGAN_SERVICE_HOST}/baremetal_compute/v1" \
"${MOGAN_SERVICE_PROTOCOL}://${MOGAN_SERVICE_HOST}/baremetal_compute/v1"
}
function mkdir_chown_stack {
if [[ ! -d "$1" ]]; then
sudo mkdir -p "$1"
fi
sudo chown $STACK_USER "$1"
}
# Entry points
# ------------
# configure_mogan - Set config files, create data dirs, etc
function configure_mogan {
mkdir_chown_stack "${MOGAN_CONF_DIR}"
iniset ${MOGAN_CONF_FILE} DEFAULT debug ${MOGAN_DEBUG}
MOGAN_POLICY_FILE=${MOGAN_CONF_DIR}/policy.json
# Mogan Configuration
#-------------------------
# Setup keystone_authtoken section
iniset ${MOGAN_CONF_FILE} keystone_authtoken auth_uri ${KEYSTONE_SERVICE_URI}
iniset ${MOGAN_CONF_FILE} keystone_authtoken project_domain_name ${SERVICE_DOMAIN_NAME}
iniset ${MOGAN_CONF_FILE} keystone_authtoken project_name ${SERVICE_PROJECT_NAME}
iniset ${MOGAN_CONF_FILE} keystone_authtoken user_domain_name ${SERVICE_DOMAIN_NAME}
iniset ${MOGAN_CONF_FILE} keystone_authtoken username ${MOGAN_ADMIN_USER}
iniset ${MOGAN_CONF_FILE} keystone_authtoken password ${SERVICE_PASSWORD}
iniset ${MOGAN_CONF_FILE} keystone_authtoken auth_url ${KEYSTONE_AUTH_URI}
iniset ${MOGAN_CONF_FILE} keystone_authtoken auth_type "password"
# Config the transport url
iniset_rpc_backend mogan $MOGAN_CONF_FILE
# Configure the database.
iniset ${MOGAN_CONF_FILE} database connection `database_connection_url mogan`
# Setup ironic section
iniset ${MOGAN_CONF_FILE} ironic project_domain_name ${SERVICE_DOMAIN_NAME}
iniset ${MOGAN_CONF_FILE} ironic project_name ${SERVICE_PROJECT_NAME}
iniset ${MOGAN_CONF_FILE} ironic user_domain_name ${SERVICE_DOMAIN_NAME}
iniset ${MOGAN_CONF_FILE} ironic username "ironic"
iniset ${MOGAN_CONF_FILE} ironic password ${SERVICE_PASSWORD}
iniset ${MOGAN_CONF_FILE} ironic auth_url ${KEYSTONE_AUTH_URI}
iniset ${MOGAN_CONF_FILE} ironic auth_type "password"
iniset ${MOGAN_CONF_FILE} ironic api_endpoint "${KEYSTONE_AUTH_PROTOCOL}://${SERVICE_HOST}:${IRONIC_SERVICE_PORT}"
# Setup placement section
iniset ${MOGAN_CONF_FILE} placement os_region_name ${REGION_NAME}
iniset ${MOGAN_CONF_FILE} placement project_domain_name ${SERVICE_DOMAIN_NAME}
iniset ${MOGAN_CONF_FILE} placement project_name ${SERVICE_PROJECT_NAME}
iniset ${MOGAN_CONF_FILE} placement user_domain_name ${SERVICE_DOMAIN_NAME}
iniset ${MOGAN_CONF_FILE} placement username "placement"
iniset ${MOGAN_CONF_FILE} placement password ${SERVICE_PASSWORD}
iniset ${MOGAN_CONF_FILE} placement auth_url ${KEYSTONE_AUTH_URI}
iniset ${MOGAN_CONF_FILE} placement auth_type "password"
# Setup neutron section
iniset ${MOGAN_CONF_FILE} neutron url "${NEUTRON_SERVICE_PROTOCOL}://${SERVICE_HOST}:${NEUTRON_SERVICE_PORT}"
# Setup glance section
if [[ "$WSGI_MODE" == "uwsgi" ]]; then
glance_url="$GLANCE_SERVICE_PROTOCOL://$GLANCE_SERVICE_HOST/image"
else
glance_url="$GLANCE_SERVICE_PROTOCOL://${SERVICE_HOST}:$GLANCE_HOSTPORT"
fi
iniset ${MOGAN_CONF_FILE} glance glance_api_servers ${glance_url}
# Setup keystone section
iniset ${MOGAN_CONF_FILE} keystone region_name ${REGION_NAME}
# Set shellinbox console url.
if is_service_enabled mogan-shellinaboxproxy; then
iniset ${MOGAN_CONF_FILE} shellinabox_console shellinabox_base_url "http://$SERVICE_HOST:8866/"
fi
# Path of policy.json file.
iniset ${MOGAN_CONF_FILE} oslo_policy policy_file ${MOGAN_POLICY_FILE}
if [ "$LOG_COLOR" == "True" ] && [ "$SYSLOG" == "False" ]; then
setup_colorized_logging ${MOGAN_CONF_FILE} DEFAULT tenant user
fi
# uWSGI configuration
write_uwsgi_config "$MOGAN_UWSGI_CONF" "$MOGAN_UWSGI_APP" "/baremetal_compute"
}
# init_mogan - Initialize the database
function init_mogan {
# (re)create Mogan database
recreate_database mogan utf8
${MOGAN_BIN_DIR}/mogan-dbsync --config-file ${MOGAN_CONF_FILE} upgrade
}
# install_mogan - Collect source and prepare
function install_mogan {
# make sure all needed service were enabled
local req_services="key glance neutron ironic"
for srv in $req_services; do
if ! is_service_enabled "$srv"; then
die $LINENO "$srv should be enabled for Mogan."
fi
done
pip_install uwsgi
setup_develop ${MOGAN_DIR}
}
function install_mogan_pythonclient {
echo_summary "Installing python-moganclient"
git_clone ${MOGAN_PYTHONCLIENT_REPO} ${MOGAN_PYTHONCLIENT_DIR} ${MOGAN_PYTHONCLIENT_BRANCH}
setup_develop ${MOGAN_PYTHONCLIENT_DIR}
}
# start_mogan - Start running processes, including screen
function start_mogan {
if is_service_enabled mogan-api && is_service_enabled mogan-engine && is_service_enabled mogan-scheduler; then
echo_summary "Installing all mogan services in separate processes"
run_process mogan-api "$MOGAN_BIN_DIR/uwsgi --ini $MOGAN_UWSGI_CONF"
if ! wait_for_service ${SERVICE_TIMEOUT} ${MOGAN_SERVICE_PROTOCOL}://${MOGAN_SERVICE_HOST}/baremetal_compute; then
die $LINENO "mogan-api did not start"
fi
run_process mogan-engine "${MOGAN_BIN_DIR}/mogan-engine --config-file ${MOGAN_CONF_DIR}/mogan.conf"
run_process mogan-scheduler "${MOGAN_BIN_DIR}/mogan-scheduler --config-file ${MOGAN_CONF_DIR}/mogan.conf"
fi
run_process mogan-consoleauth "${MOGAN_BIN_DIR}/mogan-consoleauth --config-file ${MOGAN_CONF_DIR}/mogan.conf"
run_process mogan-shellinaboxproxy "${MOGAN_BIN_DIR}/mogan-shellinaboxproxy --config-file ${MOGAN_CONF_DIR}/mogan.conf"
}
# stop_mogan - Stop running processes
function stop_mogan {
# Kill the Mogan screen windows
for serv in mogan-api mogan-engine mogan-scheduler mogan-consoleauth mogan-shellinaboxproxy; do
stop_process $serv
done
remove_uwsgi_config "$MOGAN_UWSGI_CONF" "$MOGAN_UWSGI_APP"
}
function cleanup_mogan {
echo_summary "Cleanup mogan"
}
function create_flavor {
if [[ "$IRONIC_IS_HARDWARE" == "False" ]]; then
local ironic_node_cpu=$IRONIC_VM_SPECS_CPU
local ironic_node_ram=$IRONIC_VM_SPECS_RAM
local ironic_node_disk=$IRONIC_VM_SPECS_DISK
else
local ironic_node_cpu=$IRONIC_HW_NODE_CPU
local ironic_node_ram=$IRONIC_HW_NODE_RAM
local ironic_node_disk=$IRONIC_HW_NODE_DISK
fi
name="baremetal_${ironic_node_cpu}cpu_${ironic_node_ram}mbram_${ironic_node_disk}gbdisk"
description="CPU: ${ironic_node_cpu}, RAM: ${ironic_node_ram}MB, DISK: ${ironic_node_disk}GB"
openstack baremetalcompute flavor create ${name} --description "${description}" --resource $IRONIC_DEFAULT_RESOURCE_CLASS=1
}
if is_service_enabled mogan; then
if [[ "$1" == "stack" && "$2" == "install" ]]; then
echo_summary "Installing mogan"
if [[ "$IRONIC_USE_RESOURCE_CLASSES" == "False" ]]; then
die "Ironic node resource class is required for Mogan"
fi
install_mogan
install_mogan_pythonclient
# TODO(zhenguo): Remove this when placement is started as a separated service
if ! is_service_enabled placement; then
install_placement
fi
elif [[ "$1" == "stack" && "$2" == "post-config" ]]; then
echo_summary "Configuring mogan"
if is_service_enabled tempest; then
iniset $TEMPESTCONFIG compute fixed_network_name $PRIVATE_NETWORK_NAME
fi
configure_mogan
create_mogan_accounts
# TODO(zhenguo): Remove this when placement is started as a separated service
if ! is_service_enabled placement; then
configure_placement
fi
elif [[ "$1" == "stack" && "$2" == "extra" ]]; then
# TODO(zhenguo): Remove this when placement is started as a separated service
if ! is_service_enabled placement; then
init_placement
start_placement
fi
echo_summary "Initializing mogan"
init_mogan
start_mogan
echo_summary "Creating flavor"
create_flavor
fi
if [[ "$1" == "unstack" ]]; then
echo_summary "Shutting down mogan"
stop_mogan
# TODO(zhenguo): Remove this when placement is started as a separated service
if ! is_service_enabled placement; then
stop_placement
fi
fi
if [[ "$1" == "clean" ]]; then
echo_summary "Cleaning mogan"
# TODO(zhenguo): Remove this when placement is started as a separated service
if ! is_service_enabled placement; then
cleanup_placement
fi
fi
fi
# Restore xtrace
$XTRACE
# Local variables:
# mode: shell-script
# End: