diff --git a/lib/ceilometer b/lib/ceilometer index 9db0640940..a464c52b6c 100644 --- a/lib/ceilometer +++ b/lib/ceilometer @@ -322,6 +322,8 @@ function install_ceilometermiddleware { if use_library_from_git "ceilometermiddleware"; then git_clone_by_name "ceilometermiddleware" setup_dev_lib "ceilometermiddleware" + else + pip_install ceilometermiddleware fi } diff --git a/lib/rpc_backend b/lib/rpc_backend index ff22bbf8fa..a399d1757e 100644 --- a/lib/rpc_backend +++ b/lib/rpc_backend @@ -233,6 +233,15 @@ function restart_rpc_backend { fi } +# builds transport url string +function get_transport_url { + if is_service_enabled qpid || [ -n "$QPID_HOST" ]; then + echo "qpid://$QPID_USERNAME:$QPID_PASSWORD@$QPID_HOST:5672/" + elif is_service_enabled rabbit || { [ -n "$RABBIT_HOST" ] && [ -n "$RABBIT_PASSWORD" ]; }; then + echo "rabbit://$RABBIT_USERID:$RABBIT_PASSWORD@$RABBIT_HOST:5672/" + fi +} + # iniset cofiguration function iniset_rpc_backend { local package=$1 diff --git a/lib/swift b/lib/swift index 4a63500b54..3decd2f9f0 100644 --- a/lib/swift +++ b/lib/swift @@ -378,7 +378,11 @@ function configure_swift { # Configure Ceilometer if is_service_enabled ceilometer; then iniset ${SWIFT_CONFIG_PROXY_SERVER} filter:ceilometer "set log_level" "WARN" - iniset ${SWIFT_CONFIG_PROXY_SERVER} filter:ceilometer use "egg:ceilometer#swift" + iniset ${SWIFT_CONFIG_PROXY_SERVER} filter:ceilometer paste.filter_factory "ceilometermiddleware.swift:filter_factory" + iniset ${SWIFT_CONFIG_PROXY_SERVER} filter:ceilometer control_exchange "swift" + iniset ${SWIFT_CONFIG_PROXY_SERVER} filter:ceilometer url $(get_transport_url) + iniset ${SWIFT_CONFIG_PROXY_SERVER} filter:ceilometer driver "messaging" + iniset ${SWIFT_CONFIG_PROXY_SERVER} filter:ceilometer topic "notifications" SWIFT_EXTRAS_MIDDLEWARE_LAST="${SWIFT_EXTRAS_MIDDLEWARE_LAST} ceilometer" fi diff --git a/stack.sh b/stack.sh index 615b77f249..eac7eec724 100755 --- a/stack.sh +++ b/stack.sh @@ -746,6 +746,9 @@ if is_service_enabled keystone; then fi if is_service_enabled s-proxy; then + if is_service_enabled ceilometer; then + install_ceilometermiddleware + fi stack_install_service swift configure_swift