blob: dfa3452f0dabb9e1536568c00b1c92513994e0be [file] [log] [blame]
Sean Daguee263c822014-12-05 14:25:28 -05001#!/bin/bash
2#
Malini Kamalambal9504bb32014-08-01 17:41:08 -04003# lib/zaqar
4# Install and start **Zaqar** service
5
6# To enable a minimal set of Zaqar services, add the following to localrc:
7#
8# enable_service zaqar-server
9#
10# Dependencies:
11# - functions
12# - OS_AUTH_URL for auth in api
13# - DEST set to the destination directory
14# - SERVICE_PASSWORD, SERVICE_TENANT_NAME for auth in api
15# - STACK_USER service user
16
17# stack.sh
18# ---------
19# install_zaqar
20# configure_zaqar
21# init_zaqar
22# start_zaqar
23# stop_zaqar
24# cleanup_zaqar
Flavio Percocodec13c32014-09-08 09:48:27 +020025# cleanup_zaqar_mongodb
Malini Kamalambal9504bb32014-08-01 17:41:08 -040026
27# Save trace setting
28XTRACE=$(set +o | grep xtrace)
29set +o xtrace
30
31
32# Defaults
33# --------
34
35# Set up default directories
36ZAQAR_DIR=$DEST/zaqar
37ZAQARCLIENT_DIR=$DEST/python-zaqarclient
38ZAQAR_CONF_DIR=/etc/zaqar
39ZAQAR_CONF=$ZAQAR_CONF_DIR/zaqar.conf
40ZAQAR_API_LOG_DIR=/var/log/zaqar
41ZAQAR_API_LOG_FILE=$ZAQAR_API_LOG_DIR/queues.log
42ZAQAR_AUTH_CACHE_DIR=${ZAQAR_AUTH_CACHE_DIR:-/var/cache/zaqar}
43
44# Support potential entry-points console scripts
45ZAQAR_BIN_DIR=$(get_python_exec_prefix)
46
47# Set up database backend
48ZAQAR_BACKEND=${ZAQAR_BACKEND:-mongodb}
49
50
51# Set Zaqar repository
52ZAQAR_REPO=${ZAQAR_REPO:-${GIT_BASE}/openstack/zaqar.git}
53ZAQAR_BRANCH=${ZAQAR_BRANCH:-master}
54
55# Set client library repository
56ZAQARCLIENT_REPO=${ZAQARCLIENT_REPO:-${GIT_BASE}/openstack/python-zaqarclient.git}
57ZAQARCLIENT_BRANCH=${ZAQARCLIENT_BRANCH:-master}
58
59# Set Zaqar Connection Info
60ZAQAR_SERVICE_HOST=${ZAQAR_SERVICE_HOST:-$SERVICE_HOST}
61ZAQAR_SERVICE_PORT=${ZAQAR_SERVICE_PORT:-8888}
62ZAQAR_SERVICE_PROTOCOL=${ZAQAR_SERVICE_PROTOCOL:-$SERVICE_PROTOCOL}
63
64# Tell Tempest this project is present
65TEMPEST_SERVICES+=,zaqar
66
67
68# Functions
69# ---------
70
71# Test if any Zaqar services are enabled
72# is_zaqar_enabled
73function is_zaqar_enabled {
74 [[ ,${ENABLED_SERVICES} =~ ,"zaqar-" ]] && return 0
75 return 1
76}
77
Flavio Percocodec13c32014-09-08 09:48:27 +020078# cleanup_zaqar() - Cleans up general things from previous
79# runs and storage specific left overs.
Malini Kamalambal9504bb32014-08-01 17:41:08 -040080function cleanup_zaqar {
Flavio Percocodec13c32014-09-08 09:48:27 +020081 if [ "$ZAQAR_BACKEND" = 'mongodb' ] ; then
82 cleanup_zaqar_mongodb
83 fi
84}
85
86# cleanup_zaqar_mongodb() - Remove residual data files, anything left over from previous
87# runs that a clean run would need to clean up
88function cleanup_zaqar_mongodb {
Malini Kamalambal9504bb32014-08-01 17:41:08 -040089 if ! timeout $SERVICE_TIMEOUT sh -c "while ! mongo zaqar --eval 'db.dropDatabase();'; do sleep 1; done"; then
90 die $LINENO "Mongo DB did not start"
91 else
92 full_version=$(mongo zaqar --eval 'db.dropDatabase();')
93 mongo_version=`echo $full_version | cut -d' ' -f4`
94 required_mongo_version='2.2'
95 if [[ $mongo_version < $required_mongo_version ]]; then
96 die $LINENO "Zaqar needs Mongo DB version >= 2.2 to run."
97 fi
98 fi
99}
100
101# configure_zaqarclient() - Set config files, create data dirs, etc
102function configure_zaqarclient {
103 setup_develop $ZAQARCLIENT_DIR
104}
105
106# configure_zaqar() - Set config files, create data dirs, etc
107function configure_zaqar {
108 setup_develop $ZAQAR_DIR
109
110 [ ! -d $ZAQAR_CONF_DIR ] && sudo mkdir -m 755 -p $ZAQAR_CONF_DIR
111 sudo chown $USER $ZAQAR_CONF_DIR
112
113 [ ! -d $ZAQAR_API_LOG_DIR ] && sudo mkdir -m 755 -p $ZAQAR_API_LOG_DIR
114 sudo chown $USER $ZAQAR_API_LOG_DIR
115
Victoria Martinez de la Cruz5bef3e12014-12-04 10:24:37 -0300116 iniset $ZAQAR_CONF DEFAULT debug True
Malini Kamalambal9504bb32014-08-01 17:41:08 -0400117 iniset $ZAQAR_CONF DEFAULT verbose True
Flavio Percocob64738f2014-11-24 16:44:50 +0100118 iniset $ZAQAR_CONF DEFAULT admin_mode True
Malini Kamalambal9504bb32014-08-01 17:41:08 -0400119 iniset $ZAQAR_CONF DEFAULT use_syslog $SYSLOG
120 iniset $ZAQAR_CONF DEFAULT log_file $ZAQAR_API_LOG_FILE
121 iniset $ZAQAR_CONF 'drivers:transport:wsgi' bind $ZAQAR_SERVICE_HOST
122
Brant Knudson05952372014-09-19 17:22:22 -0500123 configure_auth_token_middleware $ZAQAR_CONF zaqar $ZAQAR_AUTH_CACHE_DIR
Malini Kamalambal9504bb32014-08-01 17:41:08 -0400124
125 if [ "$ZAQAR_BACKEND" = 'mysql' ] || [ "$ZAQAR_BACKEND" = 'postgresql' ] ; then
126 iniset $ZAQAR_CONF drivers storage sqlalchemy
127 iniset $ZAQAR_CONF 'drivers:storage:sqlalchemy' uri `database_connection_url zaqar`
128 elif [ "$ZAQAR_BACKEND" = 'mongodb' ] ; then
129 iniset $ZAQAR_CONF drivers storage mongodb
130 iniset $ZAQAR_CONF 'drivers:storage:mongodb' uri mongodb://localhost:27017/zaqar
131 configure_mongodb
Flavio Percocoe29a55a2014-09-05 16:03:01 +0200132 elif [ "$ZAQAR_BACKEND" = 'redis' ] ; then
133 iniset $ZAQAR_CONF drivers storage redis
134 iniset $ZAQAR_CONF 'drivers:storage:redis' uri redis://localhost:6379
135 configure_redis
Malini Kamalambal9504bb32014-08-01 17:41:08 -0400136 fi
Flavio Percocodec13c32014-09-08 09:48:27 +0200137
Zhi Yan Liu0f52d932014-12-30 14:37:02 +0800138 if is_service_enabled qpid || [ -n "$RABBIT_HOST" ] && [ -n "$RABBIT_PASSWORD" ]; then
139 iniset $ZAQAR_CONF DEFAULT notification_driver messaging
140 iniset $ZAQAR_CONF DEFAULT control_exchange zaqar
141 fi
142 iniset_rpc_backend zaqar $ZAQAR_CONF DEFAULT
143
Flavio Percocodec13c32014-09-08 09:48:27 +0200144 cleanup_zaqar
Malini Kamalambal9504bb32014-08-01 17:41:08 -0400145}
146
Flavio Percocoe29a55a2014-09-05 16:03:01 +0200147function configure_redis {
148 if is_ubuntu; then
149 install_package redis-server
150 elif is_fedora; then
151 install_package redis
152 else
153 exit_distro_not_supported "redis installation"
154 fi
155
156 install_package python-redis
157}
158
Malini Kamalambal9504bb32014-08-01 17:41:08 -0400159function configure_mongodb {
160 # Set nssize to 2GB. This increases the number of namespaces supported
161 # # per database.
162 if is_ubuntu; then
163 sudo sed -i -e "
164 s|[^ \t]*#[ \t]*\(nssize[ \t]*=.*\$\)|\1|
165 s|^\(nssize[ \t]*=[ \t]*\).*\$|\1 2047|
166 " /etc/mongodb.conf
167 restart_service mongodb
168 elif is_fedora; then
169 sudo sed -i '/--nssize/!s/OPTIONS=\"/OPTIONS=\"--nssize 2047 /' /etc/sysconfig/mongod
170 restart_service mongod
171 fi
172}
173
174# init_zaqar() - Initialize etc.
175function init_zaqar {
176 # Create cache dir
177 sudo mkdir -p $ZAQAR_AUTH_CACHE_DIR
178 sudo chown $STACK_USER $ZAQAR_AUTH_CACHE_DIR
179 rm -f $ZAQAR_AUTH_CACHE_DIR/*
180}
181
182# install_zaqar() - Collect source and prepare
183function install_zaqar {
184 git_clone $ZAQAR_REPO $ZAQAR_DIR $ZAQAR_BRANCH
185 setup_develop $ZAQAR_DIR
186}
187
188# install_zaqarclient() - Collect source and prepare
189function install_zaqarclient {
190 git_clone $ZAQARCLIENT_REPO $ZAQARCLIENT_DIR $ZAQARCLIENT_BRANCH
191 setup_develop $ZAQARCLIENT_DIR
192}
193
194# start_zaqar() - Start running processes, including screen
195function start_zaqar {
196 if [[ "$USE_SCREEN" = "False" ]]; then
Chris Dent2f27a0e2014-09-09 13:46:02 +0100197 run_process zaqar-server "zaqar-server --config-file $ZAQAR_CONF --daemon"
Malini Kamalambal9504bb32014-08-01 17:41:08 -0400198 else
Chris Dent2f27a0e2014-09-09 13:46:02 +0100199 run_process zaqar-server "zaqar-server --config-file $ZAQAR_CONF"
Malini Kamalambal9504bb32014-08-01 17:41:08 -0400200 fi
201
202 echo "Waiting for Zaqar to start..."
203 if ! timeout $SERVICE_TIMEOUT sh -c "while ! wget --no-proxy -q -O- $ZAQAR_SERVICE_PROTOCOL://$ZAQAR_SERVICE_HOST:$ZAQAR_SERVICE_PORT/v1/health; do sleep 1; done"; then
204 die $LINENO "Zaqar did not start"
205 fi
206}
207
208# stop_zaqar() - Stop running processes
209function stop_zaqar {
Dean Troyer64309192014-08-19 22:17:50 -0500210 local serv
Malini Kamalambal9504bb32014-08-01 17:41:08 -0400211 # Kill the zaqar screen windows
212 for serv in zaqar-server; do
213 screen -S $SCREEN_NAME -p $serv -X kill
214 done
215}
216
217function create_zaqar_accounts {
Dean Troyer64309192014-08-19 22:17:50 -0500218 local service_tenant=$(openstack project list | awk "/ $SERVICE_TENANT_NAME / { print \$2 }")
Malini Kamalambal9504bb32014-08-01 17:41:08 -0400219 ADMIN_ROLE=$(openstack role list | awk "/ admin / { print \$2 }")
220
Dean Troyer64309192014-08-19 22:17:50 -0500221 local zaqar_user=$(get_or_create_user "zaqar" \
222 "$SERVICE_PASSWORD" $service_tenant)
223 get_or_add_user_role $ADMIN_ROLE $zaqar_user $service_tenant
Malini Kamalambal9504bb32014-08-01 17:41:08 -0400224
225 if [[ "$KEYSTONE_CATALOG_BACKEND" = 'sql' ]]; then
226
Dean Troyer64309192014-08-19 22:17:50 -0500227 local zaqar_service=$(get_or_create_service "zaqar" \
Victoria Martínez de la Cruzf080e892014-09-19 19:07:10 -0300228 "messaging" "Zaqar Service")
Dean Troyer64309192014-08-19 22:17:50 -0500229 get_or_create_endpoint $zaqar_service \
Malini Kamalambal9504bb32014-08-01 17:41:08 -0400230 "$REGION_NAME" \
231 "$ZAQAR_SERVICE_PROTOCOL://$ZAQAR_SERVICE_HOST:$ZAQAR_SERVICE_PORT" \
232 "$ZAQAR_SERVICE_PROTOCOL://$ZAQAR_SERVICE_HOST:$ZAQAR_SERVICE_PORT" \
233 "$ZAQAR_SERVICE_PROTOCOL://$ZAQAR_SERVICE_HOST:$ZAQAR_SERVICE_PORT"
234 fi
235
236}
237
238
239# Restore xtrace
240$XTRACE
241
242# Local variables:
243# mode: shell-script
244# End: