blob: 6aaddcefad3213126a1d1acd7b4a5234319583e4 [file] [log] [blame]
John H. Tran93361642012-07-26 11:22:05 -07001# lib/ceilometer
Dean Troyer6d04fd72012-12-21 11:03:37 -06002# Install and start **Ceilometer** service
3
Eoghan Glynn8d137032013-07-30 14:14:55 +00004# To enable a minimal set of Ceilometer services, add the following to localrc:
Adam Spierscb961592013-10-05 12:11:07 +01005#
Gordon Chung1c402282013-11-26 13:30:11 -05006# enable_service ceilometer-acompute ceilometer-acentral ceilometer-anotification ceilometer-collector ceilometer-api
Eoghan Glynn8d137032013-07-30 14:14:55 +00007#
8# To ensure Ceilometer alarming services are enabled also, further add to the localrc:
Adam Spierscb961592013-10-05 12:11:07 +01009#
Eoghan Glynn19eed742013-09-20 21:11:25 +000010# enable_service ceilometer-alarm-notifier ceilometer-alarm-evaluator
Surya Prabhakar31d31852012-09-17 20:25:41 +053011
John H. Tran93361642012-07-26 11:22:05 -070012# Dependencies:
Adam Spiers6a5aa7c2013-10-24 11:27:02 +010013#
John H. Tran93361642012-07-26 11:22:05 -070014# - functions
Doug Hellmann4a2b1c62012-11-01 16:23:52 -040015# - OS_AUTH_URL for auth in api
Eoghan Glynnad80ead2012-09-27 09:36:33 +010016# - DEST set to the destination directory
Doug Hellmann4a2b1c62012-11-01 16:23:52 -040017# - SERVICE_PASSWORD, SERVICE_TENANT_NAME for auth in api
Attila Fazekas91b8d132013-01-06 22:40:09 +010018# - STACK_USER service user
John H. Tran93361642012-07-26 11:22:05 -070019
20# stack.sh
21# ---------
Adam Spiers6a5aa7c2013-10-24 11:27:02 +010022# - install_ceilometer
23# - configure_ceilometer
24# - init_ceilometer
25# - start_ceilometer
26# - stop_ceilometer
27# - cleanup_ceilometer
John H. Tran93361642012-07-26 11:22:05 -070028
Dean Troyer7903b792012-09-13 17:16:12 -050029# Save trace setting
30XTRACE=$(set +o | grep xtrace)
31set +o xtrace
John H. Tran93361642012-07-26 11:22:05 -070032
33
34# Defaults
35# --------
36
Dean Troyer6d04fd72012-12-21 11:03:37 -060037# Set up default directories
John H. Tran93361642012-07-26 11:22:05 -070038CEILOMETER_DIR=$DEST/ceilometer
Yunhong, Jiange583d9b2013-01-09 09:33:07 +080039CEILOMETERCLIENT_DIR=$DEST/python-ceilometerclient
Dean Troyer6d04fd72012-12-21 11:03:37 -060040CEILOMETER_CONF_DIR=/etc/ceilometer
41CEILOMETER_CONF=$CEILOMETER_CONF_DIR/ceilometer.conf
42CEILOMETER_API_LOG_DIR=/var/log/ceilometer-api
Lianhao Lu8c548492013-01-09 10:41:54 +080043CEILOMETER_AUTH_CACHE_DIR=${CEILOMETER_AUTH_CACHE_DIR:-/var/cache/ceilometer}
Dean Troyer6d04fd72012-12-21 11:03:37 -060044
Monty Taylor9fbeedd2012-08-17 12:52:27 -040045# Support potential entry-points console scripts
Guangyu Suo9778b3c2013-07-17 15:22:21 +080046CEILOMETER_BIN_DIR=$(get_python_exec_prefix)
John H. Tran93361642012-07-26 11:22:05 -070047
Guangyu Suo9778b3c2013-07-17 15:22:21 +080048# Set up database backend
Julien Danjou69f74572013-08-27 11:43:53 +020049CEILOMETER_BACKEND=${CEILOMETER_BACKEND:-mysql}
Dean Troyercc6b4432013-04-08 15:38:03 -050050
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010051# Ceilometer connection info.
52CEILOMETER_SERVICE_PROTOCOL=http
53CEILOMETER_SERVICE_HOST=$SERVICE_HOST
54CEILOMETER_SERVICE_PORT=${CEILOMETER_SERVICE_PORT:-8777}
Dean Troyer4237f592014-01-29 16:22:11 -060055
56# Tell Tempest this project is present
57TEMPEST_SERVICES+=,ceilometer
58
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010059
Dean Troyercc6b4432013-04-08 15:38:03 -050060# Functions
61# ---------
Dean Troyere4fa7212014-01-15 15:04:49 -060062
63# Test if any Ceilometer services are enabled
64# is_ceilometer_enabled
65function is_ceilometer_enabled {
66 [[ ,${ENABLED_SERVICES} =~ ,"ceilometer-" ]] && return 0
67 return 1
68}
69
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010070# create_ceilometer_accounts() - Set up common required ceilometer accounts
71
72create_ceilometer_accounts() {
73
Steve Martinelli19685422014-01-24 13:02:26 -060074 SERVICE_TENANT=$(openstack project list | awk "/ $SERVICE_TENANT_NAME / { print \$2 }")
75 ADMIN_ROLE=$(openstack role list | awk "/ admin / { print \$2 }")
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010076
77 # Ceilometer
78 if [[ "$ENABLED_SERVICES" =~ "ceilometer-api" ]]; then
Steve Martinelli19685422014-01-24 13:02:26 -060079 CEILOMETER_USER=$(openstack user create \
80 ceilometer \
81 --password "$SERVICE_PASSWORD" \
82 --project $SERVICE_TENANT \
83 --email ceilometer@example.com \
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010084 | grep " id " | get_field 2)
Steve Martinelli19685422014-01-24 13:02:26 -060085 openstack role add \
86 $ADMIN_ROLE \
87 --project $SERVICE_TENANT \
88 --user $CEILOMETER_USER
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010089 if [[ "$KEYSTONE_CATALOG_BACKEND" = 'sql' ]]; then
Steve Martinelli19685422014-01-24 13:02:26 -060090 CEILOMETER_SERVICE=$(openstack service create \
91 ceilometer \
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010092 --type=metering \
93 --description="OpenStack Telemetry Service" \
94 | grep " id " | get_field 2)
Steve Martinelli19685422014-01-24 13:02:26 -060095 openstack endpoint create \
96 $CEILOMETER_SERVICE \
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010097 --region RegionOne \
Steve Martinelli19685422014-01-24 13:02:26 -060098 --publicurl "$CEILOMETER_SERVICE_PROTOCOL://$CEILOMETER_SERVICE_HOST:$CEILOMETER_SERVICE_PORT/" \
99 --adminurl "$CEILOMETER_SERVICE_PROTOCOL://$CEILOMETER_SERVICE_HOST:$CEILOMETER_SERVICE_PORT/" \
100 --internalurl "$CEILOMETER_SERVICE_PROTOCOL://$CEILOMETER_SERVICE_HOST:$CEILOMETER_SERVICE_PORT/"
Dirk Muellerfa5ccff2014-01-09 13:27:35 +0100101 fi
102 fi
103}
104
Dean Troyercc6b4432013-04-08 15:38:03 -0500105
John H. Tran93361642012-07-26 11:22:05 -0700106# cleanup_ceilometer() - Remove residual data files, anything left over from previous
107# runs that a clean run would need to clean up
Ian Wienandaee18c72014-02-21 15:35:08 +1100108function cleanup_ceilometer {
Ian Wienand936284b2014-03-11 09:35:55 +1100109 if [ "$CEILOMETER_BACKEND" != 'mysql' ] && [ "$CEILOMETER_BACKEND" != 'postgresql' ] ; then
110 mongo ceilometer --eval "db.dropDatabase();"
111 fi
John H. Tran93361642012-07-26 11:22:05 -0700112}
113
Yunhong, Jiange583d9b2013-01-09 09:33:07 +0800114# configure_ceilometerclient() - Set config files, create data dirs, etc
Ian Wienandaee18c72014-02-21 15:35:08 +1100115function configure_ceilometerclient {
Yunhong, Jiange583d9b2013-01-09 09:33:07 +0800116 setup_develop $CEILOMETERCLIENT_DIR
Attila Fazekas8664ca52014-02-02 10:07:39 +0100117 sudo install -D -m 0644 -o $STACK_USER {$CEILOMETERCLIENT_DIR/tools/,/etc/bash_completion.d/}ceilometer.bash_completion
Yunhong, Jiange583d9b2013-01-09 09:33:07 +0800118}
119
John H. Tran93361642012-07-26 11:22:05 -0700120# configure_ceilometer() - Set config files, create data dirs, etc
Ian Wienandaee18c72014-02-21 15:35:08 +1100121function configure_ceilometer {
John H. Tran93361642012-07-26 11:22:05 -0700122 setup_develop $CEILOMETER_DIR
Surya Prabhakar31d31852012-09-17 20:25:41 +0530123
Doug Hellmannc5259b42012-09-22 10:52:31 -0400124 [ ! -d $CEILOMETER_CONF_DIR ] && sudo mkdir -m 755 -p $CEILOMETER_CONF_DIR
Stephan Renatuse578eff2013-11-19 13:31:04 +0100125 sudo chown $STACK_USER $CEILOMETER_CONF_DIR
Surya Prabhakar31d31852012-09-17 20:25:41 +0530126
Doug Hellmannc5259b42012-09-22 10:52:31 -0400127 [ ! -d $CEILOMETER_API_LOG_DIR ] && sudo mkdir -m 755 -p $CEILOMETER_API_LOG_DIR
Stephan Renatuse578eff2013-11-19 13:31:04 +0100128 sudo chown $STACK_USER $CEILOMETER_API_LOG_DIR
John H. Tran93361642012-07-26 11:22:05 -0700129
Eoghan Glynn8c11f562013-03-01 12:09:01 +0000130 iniset_rpc_backend ceilometer $CEILOMETER_CONF DEFAULT
Eoghan Glynnd36268a2013-02-22 21:59:52 +0000131
Gordon Chung701eb612013-05-10 10:45:50 -0400132 iniset $CEILOMETER_CONF DEFAULT notification_topics 'notifications'
Julien Danjou4b3e4e52012-10-24 16:32:01 +0200133 iniset $CEILOMETER_CONF DEFAULT verbose True
Nadya Privalova423d7902014-03-06 15:14:59 +0400134 iniset $CEILOMETER_CONF DEFAULT debug "$ENABLE_DEBUG_LOG_LEVEL"
Doug Hellmann53a5f422012-10-02 17:29:23 -0400135
Doug Hellmann4a2b1c62012-11-01 16:23:52 -0400136 # Install the policy file for the API server
137 cp $CEILOMETER_DIR/etc/ceilometer/policy.json $CEILOMETER_CONF_DIR
Yunhong, Jiang8407b2d2013-02-07 13:48:33 +0800138 cp $CEILOMETER_DIR/etc/ceilometer/pipeline.yaml $CEILOMETER_CONF_DIR
Doug Hellmann4a2b1c62012-11-01 16:23:52 -0400139 iniset $CEILOMETER_CONF DEFAULT policy_file $CEILOMETER_CONF_DIR/policy.json
140
Mehdi Abaakouk8ceb7942013-10-23 09:26:25 +0200141 if [ "$CEILOMETER_PIPELINE_INTERVAL" ]; then
142 sed -i "s/interval:.*/interval: ${CEILOMETER_PIPELINE_INTERVAL}/" $CEILOMETER_CONF_DIR/pipeline.yaml
143 fi
144
Eoghan Glynn14246ac2012-11-14 16:23:04 +0000145 # the compute and central agents need these credentials in order to
146 # call out to the public nova and glance APIs
147 iniset $CEILOMETER_CONF DEFAULT os_username ceilometer
148 iniset $CEILOMETER_CONF DEFAULT os_password $SERVICE_PASSWORD
149 iniset $CEILOMETER_CONF DEFAULT os_tenant_name $SERVICE_TENANT_NAME
Eoghan Glynn14246ac2012-11-14 16:23:04 +0000150
Attila Fazekas2ed4ae72014-02-02 09:38:05 +0100151 iniset $CEILOMETER_CONF keystone_authtoken auth_host $KEYSTONE_AUTH_HOST
152 iniset $CEILOMETER_CONF keystone_authtoken auth_port $KEYSTONE_AUTH_PORT
153 iniset $CEILOMETER_CONF keystone_authtoken auth_protocol $KEYSTONE_AUTH_PROTOCOL
Doug Hellmann4a2b1c62012-11-01 16:23:52 -0400154 iniset $CEILOMETER_CONF keystone_authtoken admin_user ceilometer
155 iniset $CEILOMETER_CONF keystone_authtoken admin_password $SERVICE_PASSWORD
156 iniset $CEILOMETER_CONF keystone_authtoken admin_tenant_name $SERVICE_TENANT_NAME
Lianhao Lu8c548492013-01-09 10:41:54 +0800157 iniset $CEILOMETER_CONF keystone_authtoken signing_dir $CEILOMETER_AUTH_CACHE_DIR
Doug Hellmann4a2b1c62012-11-01 16:23:52 -0400158
Thomas Maddox246d9bb2013-10-24 18:57:40 +0000159 if [ "$CEILOMETER_BACKEND" = 'mysql' ] || [ "$CEILOMETER_BACKEND" = 'postgresql' ] ; then
Guangyu Suo9778b3c2013-07-17 15:22:21 +0800160 iniset $CEILOMETER_CONF database connection `database_connection_url ceilometer`
161 else
162 iniset $CEILOMETER_CONF database connection mongodb://localhost:27017/ceilometer
163 configure_mongodb
164 cleanup_ceilometer
165 fi
John H. Tran93361642012-07-26 11:22:05 -0700166}
167
Ian Wienandaee18c72014-02-21 15:35:08 +1100168function configure_mongodb {
Ian Wienand936284b2014-03-11 09:35:55 +1100169 # server package is the same on all
170 local packages=mongodb-server
171
Dean Troyercc6b4432013-04-08 15:38:03 -0500172 if is_fedora; then
Ian Wienand936284b2014-03-11 09:35:55 +1100173 # mongodb client + python bindings
174 packages="${packages} mongodb pymongo"
175 else
176 packages="${packages} python-pymongo"
177 fi
178
179 install_package ${packages}
180
181 if is_fedora; then
Eoghan Glynn285c75e2013-03-04 13:13:03 -0500182 # ensure smallfiles selected to minimize freespace requirements
183 sudo sed -i '/--smallfiles/!s/OPTIONS=\"/OPTIONS=\"--smallfiles /' /etc/sysconfig/mongod
184
185 restart_service mongod
186 fi
Ian Wienand936284b2014-03-11 09:35:55 +1100187
188 # give mongodb time to start-up
189 sleep 5
Eoghan Glynn285c75e2013-03-04 13:13:03 -0500190}
191
Lianhao Lu8c548492013-01-09 10:41:54 +0800192# init_ceilometer() - Initialize etc.
Ian Wienandaee18c72014-02-21 15:35:08 +1100193function init_ceilometer {
Lianhao Lu8c548492013-01-09 10:41:54 +0800194 # Create cache dir
195 sudo mkdir -p $CEILOMETER_AUTH_CACHE_DIR
Attila Fazekas91b8d132013-01-06 22:40:09 +0100196 sudo chown $STACK_USER $CEILOMETER_AUTH_CACHE_DIR
Lianhao Lu8c548492013-01-09 10:41:54 +0800197 rm -f $CEILOMETER_AUTH_CACHE_DIR/*
Guangyu Suo9778b3c2013-07-17 15:22:21 +0800198
Sean Daguec921a952014-02-28 21:09:33 -0500199 if is_service_enabled mysql postgresql; then
200 if [ "$CEILOMETER_BACKEND" = 'mysql' ] || [ "$CEILOMETER_BACKEND" = 'postgresql' ] ; then
201 recreate_database ceilometer utf8
202 $CEILOMETER_BIN_DIR/ceilometer-dbsync
203 fi
Guangyu Suo9778b3c2013-07-17 15:22:21 +0800204 fi
Lianhao Lu8c548492013-01-09 10:41:54 +0800205}
206
John H. Tran93361642012-07-26 11:22:05 -0700207# install_ceilometer() - Collect source and prepare
Ian Wienandaee18c72014-02-21 15:35:08 +1100208function install_ceilometer {
John H. Tran93361642012-07-26 11:22:05 -0700209 git_clone $CEILOMETER_REPO $CEILOMETER_DIR $CEILOMETER_BRANCH
210}
211
Yunhong, Jiange583d9b2013-01-09 09:33:07 +0800212# install_ceilometerclient() - Collect source and prepare
Ian Wienandaee18c72014-02-21 15:35:08 +1100213function install_ceilometerclient {
Yunhong, Jiange583d9b2013-01-09 09:33:07 +0800214 git_clone $CEILOMETERCLIENT_REPO $CEILOMETERCLIENT_DIR $CEILOMETERCLIENT_BRANCH
215}
216
John H. Tran93361642012-07-26 11:22:05 -0700217# start_ceilometer() - Start running processes, including screen
Ian Wienandaee18c72014-02-21 15:35:08 +1100218function start_ceilometer {
Mehdi Abaakoukfc1b7782013-10-23 06:46:43 +0000219 if [[ "$VIRT_DRIVER" = 'libvirt' ]]; then
220 screen_it ceilometer-acompute "cd ; sg $LIBVIRT_GROUP \"ceilometer-agent-compute --config-file $CEILOMETER_CONF\""
221 fi
Mehdi Abaakouk6d4a9a82013-10-14 16:20:32 +0200222 screen_it ceilometer-acentral "cd ; ceilometer-agent-central --config-file $CEILOMETER_CONF"
Gordon Chung1c402282013-11-26 13:30:11 -0500223 screen_it ceilometer-anotification "cd ; ceilometer-agent-notification --config-file $CEILOMETER_CONF"
Mehdi Abaakouk6d4a9a82013-10-14 16:20:32 +0200224 screen_it ceilometer-collector "cd ; ceilometer-collector --config-file $CEILOMETER_CONF"
225 screen_it ceilometer-api "cd ; ceilometer-api -d -v --log-dir=$CEILOMETER_API_LOG_DIR --config-file $CEILOMETER_CONF"
Mehdi Abaakouk1ed64cb2013-10-23 10:37:05 +0200226
Sean Dague7083b822014-02-28 20:16:20 -0500227 # only die on API if it was actually intended to be turned on
Sean Dagueb9a70352014-03-04 15:02:04 -0500228 if is_service_enabled ceilometer-api; then
Sean Dague7083b822014-02-28 20:16:20 -0500229 echo "Waiting for ceilometer-api to start..."
230 if ! timeout $SERVICE_TIMEOUT sh -c "while ! curl --noproxy '*' -s http://localhost:8777/v2/ >/dev/null; do sleep 1; done"; then
231 die $LINENO "ceilometer-api did not start"
232 fi
Mehdi Abaakouk1ed64cb2013-10-23 10:37:05 +0200233 fi
234
Mehdi Abaakouk6d4a9a82013-10-14 16:20:32 +0200235 screen_it ceilometer-alarm-notifier "cd ; ceilometer-alarm-notifier --config-file $CEILOMETER_CONF"
236 screen_it ceilometer-alarm-evaluator "cd ; ceilometer-alarm-evaluator --config-file $CEILOMETER_CONF"
John H. Tran93361642012-07-26 11:22:05 -0700237}
Dean Troyer7903b792012-09-13 17:16:12 -0500238
Dean Troyer699a29f2012-09-10 14:10:27 -0500239# stop_ceilometer() - Stop running processes
Ian Wienandaee18c72014-02-21 15:35:08 +1100240function stop_ceilometer {
Dean Troyer699a29f2012-09-10 14:10:27 -0500241 # Kill the ceilometer screen windows
Gordon Chung1c402282013-11-26 13:30:11 -0500242 for serv in ceilometer-acompute ceilometer-acentral ceilometer-anotification ceilometer-collector ceilometer-api ceilometer-alarm-notifier ceilometer-alarm-evaluator; do
Dean Troyer9fc87922013-05-22 17:19:06 -0500243 screen_stop $serv
Dean Troyer699a29f2012-09-10 14:10:27 -0500244 done
245}
246
Dean Troyercc6b4432013-04-08 15:38:03 -0500247
Dean Troyer7903b792012-09-13 17:16:12 -0500248# Restore xtrace
249$XTRACE
Sean Dague584d90e2013-03-29 14:34:53 -0400250
Adam Spiers6a5aa7c2013-10-24 11:27:02 +0100251# Tell emacs to use shell-script-mode
252## Local variables:
253## mode: shell-script
254## End: