diff --git a/exercises/marconi.sh b/exercises/marconi.sh new file mode 100755 index 0000000000..1b9788dce6 --- /dev/null +++ b/exercises/marconi.sh @@ -0,0 +1,43 @@ +#!/usr/bin/env bash + +# **marconi.sh** + +# Sanity check that Marconi started if enabled + +echo "*********************************************************************" +echo "Begin DevStack Exercise: $0" +echo "*********************************************************************" + +# This script exits on an error so that errors don't compound and you see +# only the first error that occurred. +set -o errexit + +# Print the commands being run so that we can see the command that triggers +# an error. It is also useful for following allowing as the install occurs. +set -o xtrace + + +# Settings +# ======== + +# Keep track of the current directory +EXERCISE_DIR=$(cd $(dirname "$0") && pwd) +TOP_DIR=$(cd $EXERCISE_DIR/..; pwd) + +# Import common functions +source $TOP_DIR/functions + +# Import configuration +source $TOP_DIR/openrc + +# Import exercise configuration +source $TOP_DIR/exerciserc + +is_service_enabled marconi-server || exit 55 + +curl http://$SERVICE_HOST:8888/v1/ 2>/dev/null | grep -q 'Auth' || die $LINENO "Marconi API not functioning!" + +set +o xtrace +echo "*********************************************************************" +echo "SUCCESS: End DevStack Exercise: $0" +echo "*********************************************************************" diff --git a/extras.d/70-marconi.sh b/extras.d/70-marconi.sh new file mode 100644 index 0000000000..a96a4c546c --- /dev/null +++ b/extras.d/70-marconi.sh @@ -0,0 +1,29 @@ +# marconi.sh - Devstack extras script to install Marconi + +if is_service_enabled marconi-server; then + if [[ "$1" == "source" ]]; then + # Initial source + source $TOP_DIR/lib/marconi + elif [[ "$1" == "stack" && "$2" == "install" ]]; then + echo_summary "Installing Marconi" + install_marconiclient + install_marconi + elif [[ "$1" == "stack" && "$2" == "post-config" ]]; then + echo_summary "Configuring Marconi" + configure_marconi + configure_marconiclient + + if is_service_enabled key; then + create_marconi_accounts + fi + + elif [[ "$1" == "stack" && "$2" == "extra" ]]; then + echo_summary "Initializing Marconi" + init_marconi + start_marconi + fi + + if [[ "$1" == "unstack" ]]; then + stop_marconi + fi +fi diff --git a/files/apts/marconi-server b/files/apts/marconi-server new file mode 100644 index 0000000000..bc7ef22445 --- /dev/null +++ b/files/apts/marconi-server @@ -0,0 +1,3 @@ +python-pymongo +mongodb-server +pkg-config diff --git a/files/rpms/marconi-server b/files/rpms/marconi-server new file mode 100644 index 0000000000..d7b7ea89c1 --- /dev/null +++ b/files/rpms/marconi-server @@ -0,0 +1,3 @@ +selinux-policy-targeted +mongodb-server +pymongo diff --git a/lib/marconi b/lib/marconi new file mode 100644 index 0000000000..8e0b82b49e --- /dev/null +++ b/lib/marconi @@ -0,0 +1,171 @@ +# lib/marconi +# Install and start **Marconi** service + +# To enable a minimal set of Marconi services, add the following to localrc: +# enable_service marconi-server +# +# Dependencies: +# - functions +# - OS_AUTH_URL for auth in api +# - DEST set to the destination directory +# - SERVICE_PASSWORD, SERVICE_TENANT_NAME for auth in api +# - STACK_USER service user + +# stack.sh +# --------- +# install_marconi +# configure_marconi +# init_marconi +# start_marconi +# stop_marconi +# cleanup_marconi + +# Save trace setting +XTRACE=$(set +o | grep xtrace) +set +o xtrace + + +# Defaults +# -------- + +# Set up default directories +MARCONI_DIR=$DEST/marconi +MARCONICLIENT_DIR=$DEST/python-marconiclient +MARCONI_CONF_DIR=/etc/marconi +MARCONI_CONF=$MARCONI_CONF_DIR/marconi.conf +MARCONI_API_LOG_DIR=/var/log/marconi-api +MARCONI_AUTH_CACHE_DIR=${MARCONI_AUTH_CACHE_DIR:-/var/cache/marconi} + +# Support potential entry-points console scripts +MARCONI_BIN_DIR=$(get_python_exec_prefix) + +# Set up database backend +MARCONI_BACKEND=${MARCONI_BACKEND:-mongodb} + + +# Set Marconi repository +MARCONI_REPO=${MARCONI_REPO:-${GIT_BASE}/openstack/marconi.git} +MARCONI_BRANCH=${MARCONI_BRANCH:-master} + +# Set client library repository +MARCONICLIENT_REPO=${MARCONICLIENT_REPO:-${GIT_BASE}/openstack/python-marconiclient.git} +MARCONICLIENT_BRANCH=${MARCONICLIENT_BRANCH:-master} + +# Functions +# --------- + +# cleanup_marconi() - Remove residual data files, anything left over from previous +# runs that a clean run would need to clean up +function cleanup_marconi() { + mongo marconi --eval "db.dropDatabase();" +} + +# configure_marconiclient() - Set config files, create data dirs, etc +function configure_marconiclient() { + setup_develop $MARCONICLIENT_DIR +} + +# configure_marconi() - Set config files, create data dirs, etc +function configure_marconi() { + setup_develop $MARCONI_DIR + + [ ! -d $MARCONI_CONF_DIR ] && sudo mkdir -m 755 -p $MARCONI_CONF_DIR + sudo chown $USER $MARCONI_CONF_DIR + + [ ! -d $MARCONI_API_LOG_DIR ] && sudo mkdir -m 755 -p $MARCONI_API_LOG_DIR + sudo chown $USER $MARCONI_API_LOG_DIR + + iniset $MARCONI_CONF DEFAULT verbose True + iniset $MARCONI_CONF 'drivers:transport:wsgi' bind '0.0.0.0' + + # Install the policy file for the API server + cp $MARCONI_DIR/etc/marconi/policy.json $MARCONI_CONF_DIR + iniset $MARCONI_CONF DEFAULT policy_file $MARCONI_CONF_DIR/policy.json + + iniset $MARCONI_CONF keystone_authtoken auth_protocol http + iniset $MARCONI_CONF keystone_authtoken admin_user marconi + iniset $MARCONI_CONF keystone_authtoken admin_password $SERVICE_PASSWORD + iniset $MARCONI_CONF keystone_authtoken admin_tenant_name $SERVICE_TENANT_NAME + iniset $MARCONI_CONF keystone_authtoken signing_dir $MARCONI_AUTH_CACHE_DIR + + if [[ "$MARCONI_BACKEND" = 'mongodb' ]]; then + iniset $MARCONI_CONF database connection mongodb://localhost:27017/marconi + configure_mongodb + cleanup_marconi + fi +} + +function configure_mongodb() { + # Set nssize to 2GB. This increases the number of namespaces supported + # # per database. + sudo sed -i '/--nssize/!s/OPTIONS=\"/OPTIONS=\"--nssize 2047 /' /etc/sysconfig/mongod + + restart_service mongod +} + +# init_marconi() - Initialize etc. +function init_marconi() { + # Create cache dir + sudo mkdir -p $MARCONI_AUTH_CACHE_DIR + sudo chown $STACK_USER $MARCONI_AUTH_CACHE_DIR + rm -f $MARCONI_AUTH_CACHE_DIR/* +} + +# install_marconi() - Collect source and prepare +function install_marconi() { + git_clone $MARCONI_REPO $MARCONI_DIR $MARCONI_BRANCH + setup_develop $MARCONI_DIR +} + +# install_marconiclient() - Collect source and prepare +function install_marconiclient() { + git_clone $MARCONICLIENT_REPO $MARCONICLIENT_DIR $MARCONICLIENT_BRANCH + setup_develop $MARCONICLIENT_DIR +} + +# start_marconi() - Start running processes, including screen +function start_marconi() { + screen_it marconi-server "marconi-server --config-file $MARCONI_CONF" +} + +# stop_marconi() - Stop running processes +function stop_marconi() { + # Kill the marconi screen windows + for serv in marconi-server; do + screen -S $SCREEN_NAME -p $serv -X kill + done +} + +function create_marconi_accounts() { + SERVICE_TENANT=$(keystone tenant-list | awk "/ $SERVICE_TENANT_NAME / { print \$2 }") + ADMIN_ROLE=$(keystone role-list | awk "/ admin / { print \$2 }") + + MARCONI_USER=$(get_id keystone user-create --name=marconi \ + --pass="$SERVICE_PASSWORD" \ + --tenant_id $SERVICE_TENANT \ + --email=marconi@example.com) + keystone user-role-add --tenant-id $SERVICE_TENANT \ + --user-id $MARCONI_USER \ + --role-id $ADMIN_ROLE + if [[ "$KEYSTONE_CATALOG_BACKEND" = 'sql' ]]; then + MARCONI_SERVICE=$(get_id keystone service-create \ + --name=marconi \ + --type=queuing \ + --description="Marconi Service") + keystone endpoint-create \ + --region RegionOne \ + --service_id $MARCONI_SERVICE \ + --publicurl "http://$SERVICE_HOST:8888" \ + --adminurl "http://$SERVICE_HOST:8888" \ + --internalurl "http://$SERVICE_HOST:8888" + fi + +} + + +# Restore xtrace +$XTRACE + +# Local variables: +# mode: shell-script +# End: