blob: bbb41499bea55db45c16ca7cf8b6825e24f9f7c4 [file] [log] [blame]
Sean Daguee263c822014-12-05 14:25:28 -05001#!/bin/bash
2#
Akihiro MOTOKIb0f1c382013-01-13 17:58:12 +09003# lib/rpc_backend
Sean Dague37eca482015-06-16 07:19:22 -04004# Interface for installing RabbitMQ on the system
Akihiro MOTOKIb0f1c382013-01-13 17:58:12 +09005
6# Dependencies:
Adam Spiers6a5aa7c2013-10-24 11:27:02 +01007#
8# - ``functions`` file
Abhishek Chandad5b74c62014-12-12 02:15:55 +05309# - ``RABBIT_{HOST|PASSWORD|USERID}`` must be defined when RabbitMQ is used
Akihiro MOTOKIb0f1c382013-01-13 17:58:12 +090010
11# ``stack.sh`` calls the entry points in this order:
12#
Adam Spiers6a5aa7c2013-10-24 11:27:02 +010013# - check_rpc_backend
14# - install_rpc_backend
15# - restart_rpc_backend
Sean Dague37eca482015-06-16 07:19:22 -040016# - iniset_rpc_backend (stable interface)
17#
18# Note: if implementing an out of tree plugin for an RPC backend, you
19# should install all services through normal plugin methods, then
20# redefine ``iniset_rpc_backend`` in your code. That's the one portion
21# of this file which is a standard interface.
Akihiro MOTOKIb0f1c382013-01-13 17:58:12 +090022
23# Save trace setting
Ian Wienand523f4882015-10-13 11:03:03 +110024_XTRACE_RPC_BACKEND=$(set +o | grep xtrace)
Akihiro MOTOKIb0f1c382013-01-13 17:58:12 +090025set +o xtrace
26
melanie witt0bf25502016-08-30 22:14:04 +000027RABBIT_USERID=${RABBIT_USERID:-stackrabbit}
Pawel Koniszewski20eb2742016-12-21 13:27:09 +010028if is_service_enabled rabbit; then
29 RABBIT_HOST=${RABBIT_HOST:-$SERVICE_HOST}
30fi
melanie witt0bf25502016-08-30 22:14:04 +000031
Dean Troyercc6b4432013-04-08 15:38:03 -050032# Functions
33# ---------
Akihiro MOTOKIb0f1c382013-01-13 17:58:12 +090034
Dean Troyer995eb922013-03-07 16:11:40 -060035# clean up after rpc backend - eradicate all traces so changing backends
36# produces a clean switch
37function cleanup_rpc_backend {
38 if is_service_enabled rabbit; then
39 # Obliterate rabbitmq-server
40 uninstall_package rabbitmq-server
Sean Dague9a413ab2015-02-04 12:44:18 -050041 # in case it's not actually running, /bin/true at the end
42 sudo killall epmd || sudo killall -9 epmd || /bin/true
Dean Troyer995eb922013-03-07 16:11:40 -060043 if is_ubuntu; then
44 # And the Erlang runtime too
Sahid Orentino Ferdjaouie9648272014-02-23 18:55:51 +010045 apt_get purge -y erlang*
Dean Troyer995eb922013-03-07 16:11:40 -060046 fi
Kenneth Giusti7e58c062014-07-23 16:44:37 -040047 fi
Dean Troyer995eb922013-03-07 16:11:40 -060048}
49
Akihiro MOTOKIb0f1c382013-01-13 17:58:12 +090050# install rpc backend
Ian Wienandaee18c72014-02-21 15:35:08 +110051function install_rpc_backend {
Akihiro MOTOKIb0f1c382013-01-13 17:58:12 +090052 if is_service_enabled rabbit; then
53 # Install rabbitmq-server
Ian Wienand7ccf4e02014-07-23 14:24:11 +100054 install_package rabbitmq-server
Martin Kopecec07b342023-01-24 17:38:45 +010055 if is_fedora; then
Jan Gutter97096e02019-07-26 17:46:44 +020056 # NOTE(jangutter): If rabbitmq is not running (as in a fresh
57 # install) then rabbit_setuser triggers epmd@0.0.0.0.socket with
58 # socket activation. This fails the first time and does not get
59 # cleared. It is benign, but the workaround is to start rabbitmq a
60 # bit earlier for RPM based distros.
61 sudo systemctl --now enable rabbitmq-server
Kyle Mestery75633262016-01-07 16:46:37 -060062 fi
Zhang Jinnan4d8c03a2015-08-20 10:00:20 -040063 fi
Akihiro MOTOKIb0f1c382013-01-13 17:58:12 +090064}
65
66# restart the rpc backend
Ian Wienandaee18c72014-02-21 15:35:08 +110067function restart_rpc_backend {
Akihiro MOTOKIb0f1c382013-01-13 17:58:12 +090068 if is_service_enabled rabbit; then
69 # Start rabbitmq-server
70 echo_summary "Starting RabbitMQ"
Ben Nemecec5918f2014-01-30 16:07:23 +000071 # NOTE(bnemec): Retry initial rabbitmq configuration to deal with
72 # the fact that sometimes it fails to start properly.
Ian Wienand64b56a52014-12-16 09:53:36 +110073 # Reference: https://bugzilla.redhat.com/show_bug.cgi?id=1144100
Atsushi SAKAIfe7b56c2015-11-13 17:06:16 +090074 # NOTE(tonyb): Extend the original retry logic to only restart rabbitmq
Tony Breeds6bc905c2015-05-15 12:51:43 +100075 # every second time around the loop.
76 # See: https://bugs.launchpad.net/devstack/+bug/1449056 for details on
77 # why this is needed. This can bee seen on vivid and Debian unstable
78 # (May 2015)
79 # TODO(tonyb): Remove this when Debian and Ubuntu have a fixed systemd
80 # service file.
Dean Troyer3ef23bc2014-07-25 14:56:22 -050081 local i
Tony Breeds6bc905c2015-05-15 12:51:43 +100082 for i in `seq 20`; do
Ian Wienand64b56a52014-12-16 09:53:36 +110083 local rc=0
84
Tony Breeds6bc905c2015-05-15 12:51:43 +100085 [[ $i -eq "20" ]] && die $LINENO "Failed to set rabbitmq password"
Ian Wienand64b56a52014-12-16 09:53:36 +110086
Tony Breeds6bc905c2015-05-15 12:51:43 +100087 if [[ $(( i % 2 )) == "0" ]] ; then
88 restart_service rabbitmq-server
89 fi
Ian Wienand64b56a52014-12-16 09:53:36 +110090
91 rabbit_setuser "$RABBIT_USERID" "$RABBIT_PASSWORD" || rc=$?
92 if [ $rc -ne 0 ]; then
93 continue
94 fi
95
Ben Nemecec5918f2014-01-30 16:07:23 +000096 # change the rabbit password since the default is "guest"
Ian Wienand64b56a52014-12-16 09:53:36 +110097 sudo rabbitmqctl change_password \
98 $RABBIT_USERID $RABBIT_PASSWORD || rc=$?
99 if [ $rc -ne 0 ]; then
100 continue;
101 fi
102
103 break
Ben Nemecec5918f2014-01-30 16:07:23 +0000104 done
Jens Harbott81f67fd2017-08-29 09:52:58 +0000105 # NOTE(frickler): Remove the default guest user
106 sudo rabbitmqctl delete_user guest || true
Dan Smith6f0205b2017-02-22 05:59:30 -0800107 fi
108}
109
110# adds a vhost to the rpc backend
111function rpc_backend_add_vhost {
112 local vhost="$1"
113 if is_service_enabled rabbit; then
114 if [ -z `sudo rabbitmqctl list_vhosts | grep $vhost` ]; then
115 sudo rabbitmqctl add_vhost $vhost
116 sudo rabbitmqctl set_permissions -p $vhost $RABBIT_USERID ".*" ".*" ".*"
Kieran Spearfb2a3ae2013-03-11 23:55:49 +0000117 fi
Dan Smith6f0205b2017-02-22 05:59:30 -0800118 else
119 echo 'RPC backend does not support vhosts'
120 return 1
Akihiro MOTOKIb0f1c382013-01-13 17:58:12 +0900121 fi
122}
123
Kenneth Giustib6459042017-08-04 18:08:37 -0400124# Returns the address of the RPC backend in URL format.
gordon chungb6197e62015-02-12 15:33:35 -0500125function get_transport_url {
Mehdi Abaakouk6176ae62016-05-18 12:10:08 +0200126 local virtual_host=$1
Sean Dague37eca482015-06-16 07:19:22 -0400127 if is_service_enabled rabbit || { [ -n "$RABBIT_HOST" ] && [ -n "$RABBIT_PASSWORD" ]; }; then
Mehdi Abaakouk6176ae62016-05-18 12:10:08 +0200128 echo "rabbit://$RABBIT_USERID:$RABBIT_PASSWORD@$RABBIT_HOST:5672/$virtual_host"
gordon chungb6197e62015-02-12 15:33:35 -0500129 fi
130}
131
Kenneth Giustib6459042017-08-04 18:08:37 -0400132# Returns the address of the Notification backend in URL format. This
133# should be used to set the transport_url option in the
134# oslo_messaging_notifications group.
Thomas Herve26e431d2017-04-13 14:27:35 +0200135function get_notification_url {
136 local virtual_host=$1
137 if is_service_enabled rabbit || { [ -n "$RABBIT_HOST" ] && [ -n "$RABBIT_PASSWORD" ]; }; then
138 echo "rabbit://$RABBIT_USERID:$RABBIT_PASSWORD@$RABBIT_HOST:5672/$virtual_host"
139 fi
140}
141
Atsushi SAKAIfe7b56c2015-11-13 17:06:16 +0900142# iniset configuration
Ian Wienandaee18c72014-02-21 15:35:08 +1100143function iniset_rpc_backend {
Akihiro MOTOKIb0f1c382013-01-13 17:58:12 +0900144 local package=$1
145 local file=$2
Brant Knudson2dd110c2015-03-14 12:39:14 -0500146 local section=${3:-DEFAULT}
Mehdi Abaakouk6176ae62016-05-18 12:10:08 +0200147 local virtual_host=$4
Sean Dague37eca482015-06-16 07:19:22 -0400148 if is_service_enabled rabbit || { [ -n "$RABBIT_HOST" ] && [ -n "$RABBIT_PASSWORD" ]; }; then
Mehdi Abaakouk6176ae62016-05-18 12:10:08 +0200149 iniset $file $section transport_url $(get_transport_url "$virtual_host")
Mehdi Abaakouk7cf7a8f2015-04-09 11:46:56 +0200150 if [ -n "$RABBIT_HEARTBEAT_TIMEOUT_THRESHOLD" ]; then
151 iniset $file oslo_messaging_rabbit heartbeat_timeout_threshold $RABBIT_HEARTBEAT_TIMEOUT_THRESHOLD
152 fi
153 if [ -n "$RABBIT_HEARTBEAT_RATE" ]; then
154 iniset $file oslo_messaging_rabbit heartbeat_rate $RABBIT_HEARTBEAT_RATE
155 fi
Akihiro MOTOKIb0f1c382013-01-13 17:58:12 +0900156 fi
157}
158
Abhishek Chandad5b74c62014-12-12 02:15:55 +0530159function rabbit_setuser {
160 local user="$1" pass="$2" found="" out=""
161 out=$(sudo rabbitmqctl list_users) ||
162 { echo "failed to list users" 1>&2; return 1; }
163 found=$(echo "$out" | awk '$1 == user { print $1 }' "user=$user")
164 if [ "$found" = "$user" ]; then
165 sudo rabbitmqctl change_password "$user" "$pass" ||
166 { echo "failed changing pass for '$user'" 1>&2; return 1; }
167 else
168 sudo rabbitmqctl add_user "$user" "$pass" ||
169 { echo "failed changing pass for $user"; return 1; }
170 fi
171 sudo rabbitmqctl set_permissions "$user" ".*" ".*" ".*"
172}
173
Akihiro MOTOKIb0f1c382013-01-13 17:58:12 +0900174# Restore xtrace
Ian Wienand523f4882015-10-13 11:03:03 +1100175$_XTRACE_RPC_BACKEND
Sean Dague584d90e2013-03-29 14:34:53 -0400176
Adam Spiers6a5aa7c2013-10-24 11:27:02 +0100177# Tell emacs to use shell-script-mode
178## Local variables:
179## mode: shell-script
180## End: