blob: f1ec665886be509e7d87f97786f6f57acb57df64 [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
Boris Pavlovic46e1aba2014-07-01 14:15:52 +040056# To enable OSprofiler change value of this variable to "notifications,profiler"
57CEILOMETER_NOTIFICATION_TOPICS=${CEILOMETER_NOTIFICATION_TOPICS:-notifications}
58
Dean Troyer4237f592014-01-29 16:22:11 -060059# Tell Tempest this project is present
60TEMPEST_SERVICES+=,ceilometer
61
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010062
Dean Troyercc6b4432013-04-08 15:38:03 -050063# Functions
64# ---------
Dean Troyere4fa7212014-01-15 15:04:49 -060065
66# Test if any Ceilometer services are enabled
67# is_ceilometer_enabled
68function is_ceilometer_enabled {
69 [[ ,${ENABLED_SERVICES} =~ ,"ceilometer-" ]] && return 0
70 return 1
71}
72
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010073# create_ceilometer_accounts() - Set up common required ceilometer accounts
74
Dean Troyer42a59c22014-03-03 14:31:29 -060075# Project User Roles
76# ------------------------------------------------------------------
77# SERVICE_TENANT_NAME ceilometer admin
78# SERVICE_TENANT_NAME ceilometer ResellerAdmin (if Swift is enabled)
79
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010080create_ceilometer_accounts() {
81
Dean Troyer16ef9762014-08-19 19:31:34 -050082 local service_tenant=$(openstack project list | awk "/ $SERVICE_TENANT_NAME / { print \$2 }")
83 local admin_role=$(openstack role list | awk "/ admin / { print \$2 }")
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010084
85 # Ceilometer
86 if [[ "$ENABLED_SERVICES" =~ "ceilometer-api" ]]; then
Dean Troyer16ef9762014-08-19 19:31:34 -050087 local ceilometer_user=$(get_or_create_user "ceilometer" \
88 "$SERVICE_PASSWORD" $service_tenant)
89 get_or_add_user_role $admin_role $ceilometer_user $service_tenant
Bartosz Górski0abde392014-02-28 14:15:19 +010090
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010091 if [[ "$KEYSTONE_CATALOG_BACKEND" = 'sql' ]]; then
Dean Troyer16ef9762014-08-19 19:31:34 -050092 local ceilometer_service=$(get_or_create_service "ceilometer" \
Bartosz Górski0abde392014-02-28 14:15:19 +010093 "metering" "OpenStack Telemetry Service")
Dean Troyer16ef9762014-08-19 19:31:34 -050094 get_or_create_endpoint $ceilometer_service \
Bartosz Górski0abde392014-02-28 14:15:19 +010095 "$REGION_NAME" \
96 "$CEILOMETER_SERVICE_PROTOCOL://$CEILOMETER_SERVICE_HOST:$CEILOMETER_SERVICE_PORT/" \
97 "$CEILOMETER_SERVICE_PROTOCOL://$CEILOMETER_SERVICE_HOST:$CEILOMETER_SERVICE_PORT/" \
98 "$CEILOMETER_SERVICE_PROTOCOL://$CEILOMETER_SERVICE_HOST:$CEILOMETER_SERVICE_PORT/"
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010099 fi
Dean Troyer42a59c22014-03-03 14:31:29 -0600100 if is_service_enabled swift; then
101 # Ceilometer needs ResellerAdmin role to access swift account stats.
Bartosz Górski0abde392014-02-28 14:15:19 +0100102 get_or_add_user_role "ResellerAdmin" "ceilometer" $SERVICE_TENANT_NAME
Dean Troyer42a59c22014-03-03 14:31:29 -0600103 fi
Dirk Muellerfa5ccff2014-01-09 13:27:35 +0100104 fi
105}
106
Dean Troyercc6b4432013-04-08 15:38:03 -0500107
John H. Tran93361642012-07-26 11:22:05 -0700108# cleanup_ceilometer() - Remove residual data files, anything left over from previous
109# runs that a clean run would need to clean up
Ian Wienandaee18c72014-02-21 15:35:08 +1100110function cleanup_ceilometer {
Ian Wienand936284b2014-03-11 09:35:55 +1100111 if [ "$CEILOMETER_BACKEND" != 'mysql' ] && [ "$CEILOMETER_BACKEND" != 'postgresql' ] ; then
112 mongo ceilometer --eval "db.dropDatabase();"
113 fi
John H. Tran93361642012-07-26 11:22:05 -0700114}
115
116# configure_ceilometer() - Set config files, create data dirs, etc
Ian Wienandaee18c72014-02-21 15:35:08 +1100117function configure_ceilometer {
Doug Hellmannc5259b42012-09-22 10:52:31 -0400118 [ ! -d $CEILOMETER_CONF_DIR ] && sudo mkdir -m 755 -p $CEILOMETER_CONF_DIR
Stephan Renatuse578eff2013-11-19 13:31:04 +0100119 sudo chown $STACK_USER $CEILOMETER_CONF_DIR
Surya Prabhakar31d31852012-09-17 20:25:41 +0530120
Doug Hellmannc5259b42012-09-22 10:52:31 -0400121 [ ! -d $CEILOMETER_API_LOG_DIR ] && sudo mkdir -m 755 -p $CEILOMETER_API_LOG_DIR
Stephan Renatuse578eff2013-11-19 13:31:04 +0100122 sudo chown $STACK_USER $CEILOMETER_API_LOG_DIR
John H. Tran93361642012-07-26 11:22:05 -0700123
Eoghan Glynn8c11f562013-03-01 12:09:01 +0000124 iniset_rpc_backend ceilometer $CEILOMETER_CONF DEFAULT
Eoghan Glynnd36268a2013-02-22 21:59:52 +0000125
Boris Pavlovic46e1aba2014-07-01 14:15:52 +0400126 iniset $CEILOMETER_CONF DEFAULT notification_topics "$CEILOMETER_NOTIFICATION_TOPICS"
Julien Danjou4b3e4e52012-10-24 16:32:01 +0200127 iniset $CEILOMETER_CONF DEFAULT verbose True
Nadya Privalova423d7902014-03-06 15:14:59 +0400128 iniset $CEILOMETER_CONF DEFAULT debug "$ENABLE_DEBUG_LOG_LEVEL"
Doug Hellmann53a5f422012-10-02 17:29:23 -0400129
Doug Hellmann4a2b1c62012-11-01 16:23:52 -0400130 # Install the policy file for the API server
131 cp $CEILOMETER_DIR/etc/ceilometer/policy.json $CEILOMETER_CONF_DIR
132 iniset $CEILOMETER_CONF DEFAULT policy_file $CEILOMETER_CONF_DIR/policy.json
133
ZhiQiang Fan95053cf2014-05-16 16:27:41 +0800134 cp $CEILOMETER_DIR/etc/ceilometer/pipeline.yaml $CEILOMETER_CONF_DIR
135 cp $CEILOMETER_DIR/etc/ceilometer/api_paste.ini $CEILOMETER_CONF_DIR
136 cp $CEILOMETER_DIR/etc/ceilometer/event_definitions.yaml $CEILOMETER_CONF_DIR
137
Mehdi Abaakouk8ceb7942013-10-23 09:26:25 +0200138 if [ "$CEILOMETER_PIPELINE_INTERVAL" ]; then
139 sed -i "s/interval:.*/interval: ${CEILOMETER_PIPELINE_INTERVAL}/" $CEILOMETER_CONF_DIR/pipeline.yaml
140 fi
141
Eoghan Glynn14246ac2012-11-14 16:23:04 +0000142 # the compute and central agents need these credentials in order to
ZhiQiang Fan1af4afb2014-04-16 14:52:12 +0800143 # call out to other services' public APIs
144 # the alarm evaluator needs these options to call ceilometer APIs
145 iniset $CEILOMETER_CONF service_credentials os_username ceilometer
146 iniset $CEILOMETER_CONF service_credentials os_password $SERVICE_PASSWORD
147 iniset $CEILOMETER_CONF service_credentials os_tenant_name $SERVICE_TENANT_NAME
Eoghan Glynn14246ac2012-11-14 16:23:04 +0000148
Jamie Lennox3561d7f2014-05-21 17:18:43 +1000149 iniset $CEILOMETER_CONF keystone_authtoken identity_uri $KEYSTONE_AUTH_URI
Doug Hellmann4a2b1c62012-11-01 16:23:52 -0400150 iniset $CEILOMETER_CONF keystone_authtoken admin_user ceilometer
151 iniset $CEILOMETER_CONF keystone_authtoken admin_password $SERVICE_PASSWORD
152 iniset $CEILOMETER_CONF keystone_authtoken admin_tenant_name $SERVICE_TENANT_NAME
Lianhao Lu8c548492013-01-09 10:41:54 +0800153 iniset $CEILOMETER_CONF keystone_authtoken signing_dir $CEILOMETER_AUTH_CACHE_DIR
Doug Hellmann4a2b1c62012-11-01 16:23:52 -0400154
Thomas Maddox246d9bb2013-10-24 18:57:40 +0000155 if [ "$CEILOMETER_BACKEND" = 'mysql' ] || [ "$CEILOMETER_BACKEND" = 'postgresql' ] ; then
Guangyu Suo9778b3c2013-07-17 15:22:21 +0800156 iniset $CEILOMETER_CONF database connection `database_connection_url ceilometer`
157 else
158 iniset $CEILOMETER_CONF database connection mongodb://localhost:27017/ceilometer
159 configure_mongodb
160 cleanup_ceilometer
161 fi
Piyush Masrani846609b2014-03-14 19:21:48 +0530162
163 if [[ "$VIRT_DRIVER" = 'vsphere' ]]; then
164 iniset $CEILOMETER_CONF DEFAULT hypervisor_inspector vsphere
165 iniset $CEILOMETER_CONF vmware host_ip "$VMWAREAPI_IP"
166 iniset $CEILOMETER_CONF vmware host_username "$VMWAREAPI_USER"
167 iniset $CEILOMETER_CONF vmware host_password "$VMWAREAPI_PASSWORD"
168 fi
John H. Tran93361642012-07-26 11:22:05 -0700169}
170
Ian Wienandaee18c72014-02-21 15:35:08 +1100171function configure_mongodb {
Ian Wienand936284b2014-03-11 09:35:55 +1100172 # server package is the same on all
173 local packages=mongodb-server
174
Dean Troyercc6b4432013-04-08 15:38:03 -0500175 if is_fedora; then
Ian Wienand936284b2014-03-11 09:35:55 +1100176 # mongodb client + python bindings
177 packages="${packages} mongodb pymongo"
178 else
179 packages="${packages} python-pymongo"
180 fi
181
182 install_package ${packages}
183
184 if is_fedora; then
Eoghan Glynn285c75e2013-03-04 13:13:03 -0500185 # ensure smallfiles selected to minimize freespace requirements
186 sudo sed -i '/--smallfiles/!s/OPTIONS=\"/OPTIONS=\"--smallfiles /' /etc/sysconfig/mongod
187
188 restart_service mongod
189 fi
Ian Wienand936284b2014-03-11 09:35:55 +1100190
191 # give mongodb time to start-up
192 sleep 5
Eoghan Glynn285c75e2013-03-04 13:13:03 -0500193}
194
Lianhao Lu8c548492013-01-09 10:41:54 +0800195# init_ceilometer() - Initialize etc.
Ian Wienandaee18c72014-02-21 15:35:08 +1100196function init_ceilometer {
Lianhao Lu8c548492013-01-09 10:41:54 +0800197 # Create cache dir
198 sudo mkdir -p $CEILOMETER_AUTH_CACHE_DIR
Attila Fazekas91b8d132013-01-06 22:40:09 +0100199 sudo chown $STACK_USER $CEILOMETER_AUTH_CACHE_DIR
Lianhao Lu8c548492013-01-09 10:41:54 +0800200 rm -f $CEILOMETER_AUTH_CACHE_DIR/*
Guangyu Suo9778b3c2013-07-17 15:22:21 +0800201
Sean Daguec921a952014-02-28 21:09:33 -0500202 if is_service_enabled mysql postgresql; then
203 if [ "$CEILOMETER_BACKEND" = 'mysql' ] || [ "$CEILOMETER_BACKEND" = 'postgresql' ] ; then
204 recreate_database ceilometer utf8
205 $CEILOMETER_BIN_DIR/ceilometer-dbsync
206 fi
Guangyu Suo9778b3c2013-07-17 15:22:21 +0800207 fi
Lianhao Lu8c548492013-01-09 10:41:54 +0800208}
209
John H. Tran93361642012-07-26 11:22:05 -0700210# install_ceilometer() - Collect source and prepare
Ian Wienandaee18c72014-02-21 15:35:08 +1100211function install_ceilometer {
John H. Tran93361642012-07-26 11:22:05 -0700212 git_clone $CEILOMETER_REPO $CEILOMETER_DIR $CEILOMETER_BRANCH
Joe Gordon13344bd2014-07-22 14:26:05 -0700213 setup_develop $CEILOMETER_DIR
214
John H. Tran93361642012-07-26 11:22:05 -0700215}
216
Yunhong, Jiange583d9b2013-01-09 09:33:07 +0800217# install_ceilometerclient() - Collect source and prepare
Ian Wienandaee18c72014-02-21 15:35:08 +1100218function install_ceilometerclient {
Yunhong, Jiange583d9b2013-01-09 09:33:07 +0800219 git_clone $CEILOMETERCLIENT_REPO $CEILOMETERCLIENT_DIR $CEILOMETERCLIENT_BRANCH
Joe Gordon13344bd2014-07-22 14:26:05 -0700220 setup_develop $CEILOMETERCLIENT_DIR
221 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 +0800222}
223
John H. Tran93361642012-07-26 11:22:05 -0700224# start_ceilometer() - Start running processes, including screen
Ian Wienandaee18c72014-02-21 15:35:08 +1100225function start_ceilometer {
Mehdi Abaakoukfc1b7782013-10-23 06:46:43 +0000226 if [[ "$VIRT_DRIVER" = 'libvirt' ]]; then
Dina Belova0f6d4532014-04-23 17:47:36 +0400227 screen_it ceilometer-acompute "cd ; sg $LIBVIRT_GROUP 'ceilometer-agent-compute --config-file $CEILOMETER_CONF'"
Mehdi Abaakoukfc1b7782013-10-23 06:46:43 +0000228 fi
Piyush Masrani846609b2014-03-14 19:21:48 +0530229 if [[ "$VIRT_DRIVER" = 'vsphere' ]]; then
230 screen_it ceilometer-acompute "cd ; ceilometer-agent-compute --config-file $CEILOMETER_CONF"
231 fi
Mehdi Abaakouk6d4a9a82013-10-14 16:20:32 +0200232 screen_it ceilometer-acentral "cd ; ceilometer-agent-central --config-file $CEILOMETER_CONF"
Gordon Chung1c402282013-11-26 13:30:11 -0500233 screen_it ceilometer-anotification "cd ; ceilometer-agent-notification --config-file $CEILOMETER_CONF"
Mehdi Abaakouk6d4a9a82013-10-14 16:20:32 +0200234 screen_it ceilometer-collector "cd ; ceilometer-collector --config-file $CEILOMETER_CONF"
235 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 +0200236
Sean Dague7083b822014-02-28 20:16:20 -0500237 # only die on API if it was actually intended to be turned on
Sean Dagueb9a70352014-03-04 15:02:04 -0500238 if is_service_enabled ceilometer-api; then
Sean Dague7083b822014-02-28 20:16:20 -0500239 echo "Waiting for ceilometer-api to start..."
240 if ! timeout $SERVICE_TIMEOUT sh -c "while ! curl --noproxy '*' -s http://localhost:8777/v2/ >/dev/null; do sleep 1; done"; then
241 die $LINENO "ceilometer-api did not start"
242 fi
Mehdi Abaakouk1ed64cb2013-10-23 10:37:05 +0200243 fi
244
Mehdi Abaakouk6d4a9a82013-10-14 16:20:32 +0200245 screen_it ceilometer-alarm-notifier "cd ; ceilometer-alarm-notifier --config-file $CEILOMETER_CONF"
246 screen_it ceilometer-alarm-evaluator "cd ; ceilometer-alarm-evaluator --config-file $CEILOMETER_CONF"
John H. Tran93361642012-07-26 11:22:05 -0700247}
Dean Troyer7903b792012-09-13 17:16:12 -0500248
Dean Troyer699a29f2012-09-10 14:10:27 -0500249# stop_ceilometer() - Stop running processes
Ian Wienandaee18c72014-02-21 15:35:08 +1100250function stop_ceilometer {
Dean Troyer699a29f2012-09-10 14:10:27 -0500251 # Kill the ceilometer screen windows
Gordon Chung1c402282013-11-26 13:30:11 -0500252 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 -0500253 screen_stop $serv
Dean Troyer699a29f2012-09-10 14:10:27 -0500254 done
255}
256
Dean Troyercc6b4432013-04-08 15:38:03 -0500257
Dean Troyer7903b792012-09-13 17:16:12 -0500258# Restore xtrace
259$XTRACE
Sean Dague584d90e2013-03-29 14:34:53 -0400260
Adam Spiers6a5aa7c2013-10-24 11:27:02 +0100261# Tell emacs to use shell-script-mode
262## Local variables:
263## mode: shell-script
264## End: