blob: b9e42a2dec675e3757d3105739308882a39fe9ba [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`
Dean Troyer05bd7b82014-09-16 17:25:33 -0500157 iniset $CEILOMETER_CONF DEFAULT collector_workers $API_WORKERS
Guangyu Suo9778b3c2013-07-17 15:22:21 +0800158 else
159 iniset $CEILOMETER_CONF database connection mongodb://localhost:27017/ceilometer
160 configure_mongodb
161 cleanup_ceilometer
162 fi
Piyush Masrani846609b2014-03-14 19:21:48 +0530163
164 if [[ "$VIRT_DRIVER" = 'vsphere' ]]; then
165 iniset $CEILOMETER_CONF DEFAULT hypervisor_inspector vsphere
166 iniset $CEILOMETER_CONF vmware host_ip "$VMWAREAPI_IP"
167 iniset $CEILOMETER_CONF vmware host_username "$VMWAREAPI_USER"
168 iniset $CEILOMETER_CONF vmware host_password "$VMWAREAPI_PASSWORD"
169 fi
John H. Tran93361642012-07-26 11:22:05 -0700170}
171
Ian Wienandaee18c72014-02-21 15:35:08 +1100172function configure_mongodb {
Ian Wienand936284b2014-03-11 09:35:55 +1100173 # server package is the same on all
174 local packages=mongodb-server
175
Dean Troyercc6b4432013-04-08 15:38:03 -0500176 if is_fedora; then
Ian Wienand936284b2014-03-11 09:35:55 +1100177 # mongodb client + python bindings
178 packages="${packages} mongodb pymongo"
179 else
180 packages="${packages} python-pymongo"
181 fi
182
183 install_package ${packages}
184
185 if is_fedora; then
Eoghan Glynn285c75e2013-03-04 13:13:03 -0500186 # ensure smallfiles selected to minimize freespace requirements
187 sudo sed -i '/--smallfiles/!s/OPTIONS=\"/OPTIONS=\"--smallfiles /' /etc/sysconfig/mongod
188
189 restart_service mongod
190 fi
Ian Wienand936284b2014-03-11 09:35:55 +1100191
192 # give mongodb time to start-up
193 sleep 5
Eoghan Glynn285c75e2013-03-04 13:13:03 -0500194}
195
Lianhao Lu8c548492013-01-09 10:41:54 +0800196# init_ceilometer() - Initialize etc.
Ian Wienandaee18c72014-02-21 15:35:08 +1100197function init_ceilometer {
Lianhao Lu8c548492013-01-09 10:41:54 +0800198 # Create cache dir
199 sudo mkdir -p $CEILOMETER_AUTH_CACHE_DIR
Attila Fazekas91b8d132013-01-06 22:40:09 +0100200 sudo chown $STACK_USER $CEILOMETER_AUTH_CACHE_DIR
Lianhao Lu8c548492013-01-09 10:41:54 +0800201 rm -f $CEILOMETER_AUTH_CACHE_DIR/*
Guangyu Suo9778b3c2013-07-17 15:22:21 +0800202
Sean Daguec921a952014-02-28 21:09:33 -0500203 if is_service_enabled mysql postgresql; then
204 if [ "$CEILOMETER_BACKEND" = 'mysql' ] || [ "$CEILOMETER_BACKEND" = 'postgresql' ] ; then
205 recreate_database ceilometer utf8
206 $CEILOMETER_BIN_DIR/ceilometer-dbsync
207 fi
Guangyu Suo9778b3c2013-07-17 15:22:21 +0800208 fi
Lianhao Lu8c548492013-01-09 10:41:54 +0800209}
210
John H. Tran93361642012-07-26 11:22:05 -0700211# install_ceilometer() - Collect source and prepare
Ian Wienandaee18c72014-02-21 15:35:08 +1100212function install_ceilometer {
John H. Tran93361642012-07-26 11:22:05 -0700213 git_clone $CEILOMETER_REPO $CEILOMETER_DIR $CEILOMETER_BRANCH
Joe Gordon13344bd2014-07-22 14:26:05 -0700214 setup_develop $CEILOMETER_DIR
215
John H. Tran93361642012-07-26 11:22:05 -0700216}
217
Yunhong, Jiange583d9b2013-01-09 09:33:07 +0800218# install_ceilometerclient() - Collect source and prepare
Ian Wienandaee18c72014-02-21 15:35:08 +1100219function install_ceilometerclient {
Yunhong, Jiange583d9b2013-01-09 09:33:07 +0800220 git_clone $CEILOMETERCLIENT_REPO $CEILOMETERCLIENT_DIR $CEILOMETERCLIENT_BRANCH
Joe Gordon13344bd2014-07-22 14:26:05 -0700221 setup_develop $CEILOMETERCLIENT_DIR
222 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 +0800223}
224
John H. Tran93361642012-07-26 11:22:05 -0700225# start_ceilometer() - Start running processes, including screen
Ian Wienandaee18c72014-02-21 15:35:08 +1100226function start_ceilometer {
Chris Dent2f27a0e2014-09-09 13:46:02 +0100227 run_process ceilometer-acentral "ceilometer-agent-central --config-file $CEILOMETER_CONF"
228 run_process ceilometer-anotification "ceilometer-agent-notification --config-file $CEILOMETER_CONF"
229 run_process ceilometer-collector "ceilometer-collector --config-file $CEILOMETER_CONF"
230 run_process ceilometer-api "ceilometer-api -d -v --log-dir=$CEILOMETER_API_LOG_DIR --config-file $CEILOMETER_CONF"
Chris Dent4922bfa2014-08-12 14:27:58 +0100231
232 # Start the compute agent last to allow time for the collector to
233 # fully wake up and connect to the message bus. See bug #1355809
Mehdi Abaakoukfc1b7782013-10-23 06:46:43 +0000234 if [[ "$VIRT_DRIVER" = 'libvirt' ]]; then
Chris Dent2f27a0e2014-09-09 13:46:02 +0100235 run_process ceilometer-acompute "sg $LIBVIRT_GROUP 'ceilometer-agent-compute --config-file $CEILOMETER_CONF'"
Mehdi Abaakoukfc1b7782013-10-23 06:46:43 +0000236 fi
Piyush Masrani846609b2014-03-14 19:21:48 +0530237 if [[ "$VIRT_DRIVER" = 'vsphere' ]]; then
Chris Dent2f27a0e2014-09-09 13:46:02 +0100238 run_process ceilometer-acompute "ceilometer-agent-compute --config-file $CEILOMETER_CONF"
Piyush Masrani846609b2014-03-14 19:21:48 +0530239 fi
Mehdi Abaakouk1ed64cb2013-10-23 10:37:05 +0200240
Sean Dague7083b822014-02-28 20:16:20 -0500241 # only die on API if it was actually intended to be turned on
Sean Dagueb9a70352014-03-04 15:02:04 -0500242 if is_service_enabled ceilometer-api; then
Sean Dague7083b822014-02-28 20:16:20 -0500243 echo "Waiting for ceilometer-api to start..."
244 if ! timeout $SERVICE_TIMEOUT sh -c "while ! curl --noproxy '*' -s http://localhost:8777/v2/ >/dev/null; do sleep 1; done"; then
245 die $LINENO "ceilometer-api did not start"
246 fi
Mehdi Abaakouk1ed64cb2013-10-23 10:37:05 +0200247 fi
248
Chris Dent2f27a0e2014-09-09 13:46:02 +0100249 run_process ceilometer-alarm-notifier "ceilometer-alarm-notifier --config-file $CEILOMETER_CONF"
250 run_process ceilometer-alarm-evaluator "ceilometer-alarm-evaluator --config-file $CEILOMETER_CONF"
John H. Tran93361642012-07-26 11:22:05 -0700251}
Dean Troyer7903b792012-09-13 17:16:12 -0500252
Dean Troyer699a29f2012-09-10 14:10:27 -0500253# stop_ceilometer() - Stop running processes
Ian Wienandaee18c72014-02-21 15:35:08 +1100254function stop_ceilometer {
Dean Troyer699a29f2012-09-10 14:10:27 -0500255 # Kill the ceilometer screen windows
Gordon Chung1c402282013-11-26 13:30:11 -0500256 for serv in ceilometer-acompute ceilometer-acentral ceilometer-anotification ceilometer-collector ceilometer-api ceilometer-alarm-notifier ceilometer-alarm-evaluator; do
Chris Dent2f27a0e2014-09-09 13:46:02 +0100257 stop_process $serv
Dean Troyer699a29f2012-09-10 14:10:27 -0500258 done
259}
260
Dean Troyercc6b4432013-04-08 15:38:03 -0500261
Dean Troyer7903b792012-09-13 17:16:12 -0500262# Restore xtrace
263$XTRACE
Sean Dague584d90e2013-03-29 14:34:53 -0400264
Adam Spiers6a5aa7c2013-10-24 11:27:02 +0100265# Tell emacs to use shell-script-mode
266## Local variables:
267## mode: shell-script
268## End: