blob: c90b8cbdd9bdc8a0760065dbb35dc6bab0278745 [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
Dean Troyer42a59c22014-03-03 14:31:29 -060072# Project User Roles
73# ------------------------------------------------------------------
74# SERVICE_TENANT_NAME ceilometer admin
75# SERVICE_TENANT_NAME ceilometer ResellerAdmin (if Swift is enabled)
76
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010077create_ceilometer_accounts() {
78
Steve Martinelli19685422014-01-24 13:02:26 -060079 SERVICE_TENANT=$(openstack project list | awk "/ $SERVICE_TENANT_NAME / { print \$2 }")
80 ADMIN_ROLE=$(openstack role list | awk "/ admin / { print \$2 }")
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010081
82 # Ceilometer
83 if [[ "$ENABLED_SERVICES" =~ "ceilometer-api" ]]; then
Bartosz Górski0abde392014-02-28 14:15:19 +010084 CEILOMETER_USER=$(get_or_create_user "ceilometer" \
85 "$SERVICE_PASSWORD" $SERVICE_TENANT "ceilometer@example.com")
86 get_or_add_user_role $ADMIN_ROLE $CEILOMETER_USER $SERVICE_TENANT
87
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010088 if [[ "$KEYSTONE_CATALOG_BACKEND" = 'sql' ]]; then
Bartosz Górski0abde392014-02-28 14:15:19 +010089 CEILOMETER_SERVICE=$(get_or_create_service "ceilometer" \
90 "metering" "OpenStack Telemetry Service")
91 get_or_create_endpoint $CEILOMETER_SERVICE \
92 "$REGION_NAME" \
93 "$CEILOMETER_SERVICE_PROTOCOL://$CEILOMETER_SERVICE_HOST:$CEILOMETER_SERVICE_PORT/" \
94 "$CEILOMETER_SERVICE_PROTOCOL://$CEILOMETER_SERVICE_HOST:$CEILOMETER_SERVICE_PORT/" \
95 "$CEILOMETER_SERVICE_PROTOCOL://$CEILOMETER_SERVICE_HOST:$CEILOMETER_SERVICE_PORT/"
Dirk Muellerfa5ccff2014-01-09 13:27:35 +010096 fi
Dean Troyer42a59c22014-03-03 14:31:29 -060097 if is_service_enabled swift; then
98 # Ceilometer needs ResellerAdmin role to access swift account stats.
Bartosz Górski0abde392014-02-28 14:15:19 +010099 get_or_add_user_role "ResellerAdmin" "ceilometer" $SERVICE_TENANT_NAME
Dean Troyer42a59c22014-03-03 14:31:29 -0600100 fi
Dirk Muellerfa5ccff2014-01-09 13:27:35 +0100101 fi
102}
103
Dean Troyercc6b4432013-04-08 15:38:03 -0500104
John H. Tran93361642012-07-26 11:22:05 -0700105# cleanup_ceilometer() - Remove residual data files, anything left over from previous
106# runs that a clean run would need to clean up
Ian Wienandaee18c72014-02-21 15:35:08 +1100107function cleanup_ceilometer {
Ian Wienand936284b2014-03-11 09:35:55 +1100108 if [ "$CEILOMETER_BACKEND" != 'mysql' ] && [ "$CEILOMETER_BACKEND" != 'postgresql' ] ; then
109 mongo ceilometer --eval "db.dropDatabase();"
110 fi
John H. Tran93361642012-07-26 11:22:05 -0700111}
112
Yunhong, Jiange583d9b2013-01-09 09:33:07 +0800113# configure_ceilometerclient() - Set config files, create data dirs, etc
Ian Wienandaee18c72014-02-21 15:35:08 +1100114function configure_ceilometerclient {
Yunhong, Jiange583d9b2013-01-09 09:33:07 +0800115 setup_develop $CEILOMETERCLIENT_DIR
Attila Fazekas8664ca52014-02-02 10:07:39 +0100116 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 +0800117}
118
John H. Tran93361642012-07-26 11:22:05 -0700119# configure_ceilometer() - Set config files, create data dirs, etc
Ian Wienandaee18c72014-02-21 15:35:08 +1100120function configure_ceilometer {
John H. Tran93361642012-07-26 11:22:05 -0700121 setup_develop $CEILOMETER_DIR
Surya Prabhakar31d31852012-09-17 20:25:41 +0530122
Doug Hellmannc5259b42012-09-22 10:52:31 -0400123 [ ! -d $CEILOMETER_CONF_DIR ] && sudo mkdir -m 755 -p $CEILOMETER_CONF_DIR
Stephan Renatuse578eff2013-11-19 13:31:04 +0100124 sudo chown $STACK_USER $CEILOMETER_CONF_DIR
Surya Prabhakar31d31852012-09-17 20:25:41 +0530125
Doug Hellmannc5259b42012-09-22 10:52:31 -0400126 [ ! -d $CEILOMETER_API_LOG_DIR ] && sudo mkdir -m 755 -p $CEILOMETER_API_LOG_DIR
Stephan Renatuse578eff2013-11-19 13:31:04 +0100127 sudo chown $STACK_USER $CEILOMETER_API_LOG_DIR
John H. Tran93361642012-07-26 11:22:05 -0700128
Eoghan Glynn8c11f562013-03-01 12:09:01 +0000129 iniset_rpc_backend ceilometer $CEILOMETER_CONF DEFAULT
Eoghan Glynnd36268a2013-02-22 21:59:52 +0000130
Gordon Chung701eb612013-05-10 10:45:50 -0400131 iniset $CEILOMETER_CONF DEFAULT notification_topics 'notifications'
Julien Danjou4b3e4e52012-10-24 16:32:01 +0200132 iniset $CEILOMETER_CONF DEFAULT verbose True
Nadya Privalova423d7902014-03-06 15:14:59 +0400133 iniset $CEILOMETER_CONF DEFAULT debug "$ENABLE_DEBUG_LOG_LEVEL"
Doug Hellmann53a5f422012-10-02 17:29:23 -0400134
Doug Hellmann4a2b1c62012-11-01 16:23:52 -0400135 # Install the policy file for the API server
136 cp $CEILOMETER_DIR/etc/ceilometer/policy.json $CEILOMETER_CONF_DIR
137 iniset $CEILOMETER_CONF DEFAULT policy_file $CEILOMETER_CONF_DIR/policy.json
138
ZhiQiang Fan95053cf2014-05-16 16:27:41 +0800139 cp $CEILOMETER_DIR/etc/ceilometer/pipeline.yaml $CEILOMETER_CONF_DIR
140 cp $CEILOMETER_DIR/etc/ceilometer/api_paste.ini $CEILOMETER_CONF_DIR
141 cp $CEILOMETER_DIR/etc/ceilometer/event_definitions.yaml $CEILOMETER_CONF_DIR
142
Mehdi Abaakouk8ceb7942013-10-23 09:26:25 +0200143 if [ "$CEILOMETER_PIPELINE_INTERVAL" ]; then
144 sed -i "s/interval:.*/interval: ${CEILOMETER_PIPELINE_INTERVAL}/" $CEILOMETER_CONF_DIR/pipeline.yaml
145 fi
146
Eoghan Glynn14246ac2012-11-14 16:23:04 +0000147 # the compute and central agents need these credentials in order to
ZhiQiang Fan1af4afb2014-04-16 14:52:12 +0800148 # call out to other services' public APIs
149 # the alarm evaluator needs these options to call ceilometer APIs
150 iniset $CEILOMETER_CONF service_credentials os_username ceilometer
151 iniset $CEILOMETER_CONF service_credentials os_password $SERVICE_PASSWORD
152 iniset $CEILOMETER_CONF service_credentials os_tenant_name $SERVICE_TENANT_NAME
Longgeek524bbed2014-06-01 23:44:21 +0800153 iniset $CEILOMETER_CONF service_credentials os_auth_url $OS_AUTH_URL
Eoghan Glynn14246ac2012-11-14 16:23:04 +0000154
Jamie Lennox3561d7f2014-05-21 17:18:43 +1000155 iniset $CEILOMETER_CONF keystone_authtoken identity_uri $KEYSTONE_AUTH_URI
Doug Hellmann4a2b1c62012-11-01 16:23:52 -0400156 iniset $CEILOMETER_CONF keystone_authtoken admin_user ceilometer
157 iniset $CEILOMETER_CONF keystone_authtoken admin_password $SERVICE_PASSWORD
158 iniset $CEILOMETER_CONF keystone_authtoken admin_tenant_name $SERVICE_TENANT_NAME
Lianhao Lu8c548492013-01-09 10:41:54 +0800159 iniset $CEILOMETER_CONF keystone_authtoken signing_dir $CEILOMETER_AUTH_CACHE_DIR
Doug Hellmann4a2b1c62012-11-01 16:23:52 -0400160
Thomas Maddox246d9bb2013-10-24 18:57:40 +0000161 if [ "$CEILOMETER_BACKEND" = 'mysql' ] || [ "$CEILOMETER_BACKEND" = 'postgresql' ] ; then
Guangyu Suo9778b3c2013-07-17 15:22:21 +0800162 iniset $CEILOMETER_CONF database connection `database_connection_url ceilometer`
163 else
164 iniset $CEILOMETER_CONF database connection mongodb://localhost:27017/ceilometer
165 configure_mongodb
166 cleanup_ceilometer
167 fi
Piyush Masrani846609b2014-03-14 19:21:48 +0530168
169 if [[ "$VIRT_DRIVER" = 'vsphere' ]]; then
170 iniset $CEILOMETER_CONF DEFAULT hypervisor_inspector vsphere
171 iniset $CEILOMETER_CONF vmware host_ip "$VMWAREAPI_IP"
172 iniset $CEILOMETER_CONF vmware host_username "$VMWAREAPI_USER"
173 iniset $CEILOMETER_CONF vmware host_password "$VMWAREAPI_PASSWORD"
174 fi
John H. Tran93361642012-07-26 11:22:05 -0700175}
176
Ian Wienandaee18c72014-02-21 15:35:08 +1100177function configure_mongodb {
Ian Wienand936284b2014-03-11 09:35:55 +1100178 # server package is the same on all
179 local packages=mongodb-server
180
Dean Troyercc6b4432013-04-08 15:38:03 -0500181 if is_fedora; then
Ian Wienand936284b2014-03-11 09:35:55 +1100182 # mongodb client + python bindings
183 packages="${packages} mongodb pymongo"
184 else
185 packages="${packages} python-pymongo"
186 fi
187
188 install_package ${packages}
189
190 if is_fedora; then
Eoghan Glynn285c75e2013-03-04 13:13:03 -0500191 # ensure smallfiles selected to minimize freespace requirements
192 sudo sed -i '/--smallfiles/!s/OPTIONS=\"/OPTIONS=\"--smallfiles /' /etc/sysconfig/mongod
193
194 restart_service mongod
195 fi
Ian Wienand936284b2014-03-11 09:35:55 +1100196
197 # give mongodb time to start-up
198 sleep 5
Eoghan Glynn285c75e2013-03-04 13:13:03 -0500199}
200
Lianhao Lu8c548492013-01-09 10:41:54 +0800201# init_ceilometer() - Initialize etc.
Ian Wienandaee18c72014-02-21 15:35:08 +1100202function init_ceilometer {
Lianhao Lu8c548492013-01-09 10:41:54 +0800203 # Create cache dir
204 sudo mkdir -p $CEILOMETER_AUTH_CACHE_DIR
Attila Fazekas91b8d132013-01-06 22:40:09 +0100205 sudo chown $STACK_USER $CEILOMETER_AUTH_CACHE_DIR
Lianhao Lu8c548492013-01-09 10:41:54 +0800206 rm -f $CEILOMETER_AUTH_CACHE_DIR/*
Guangyu Suo9778b3c2013-07-17 15:22:21 +0800207
Sean Daguec921a952014-02-28 21:09:33 -0500208 if is_service_enabled mysql postgresql; then
209 if [ "$CEILOMETER_BACKEND" = 'mysql' ] || [ "$CEILOMETER_BACKEND" = 'postgresql' ] ; then
210 recreate_database ceilometer utf8
211 $CEILOMETER_BIN_DIR/ceilometer-dbsync
212 fi
Guangyu Suo9778b3c2013-07-17 15:22:21 +0800213 fi
Lianhao Lu8c548492013-01-09 10:41:54 +0800214}
215
John H. Tran93361642012-07-26 11:22:05 -0700216# install_ceilometer() - Collect source and prepare
Ian Wienandaee18c72014-02-21 15:35:08 +1100217function install_ceilometer {
John H. Tran93361642012-07-26 11:22:05 -0700218 git_clone $CEILOMETER_REPO $CEILOMETER_DIR $CEILOMETER_BRANCH
219}
220
Yunhong, Jiange583d9b2013-01-09 09:33:07 +0800221# install_ceilometerclient() - Collect source and prepare
Ian Wienandaee18c72014-02-21 15:35:08 +1100222function install_ceilometerclient {
Yunhong, Jiange583d9b2013-01-09 09:33:07 +0800223 git_clone $CEILOMETERCLIENT_REPO $CEILOMETERCLIENT_DIR $CEILOMETERCLIENT_BRANCH
224}
225
John H. Tran93361642012-07-26 11:22:05 -0700226# start_ceilometer() - Start running processes, including screen
Ian Wienandaee18c72014-02-21 15:35:08 +1100227function start_ceilometer {
Mehdi Abaakoukfc1b7782013-10-23 06:46:43 +0000228 if [[ "$VIRT_DRIVER" = 'libvirt' ]]; then
Dina Belova0f6d4532014-04-23 17:47:36 +0400229 screen_it ceilometer-acompute "cd ; sg $LIBVIRT_GROUP 'ceilometer-agent-compute --config-file $CEILOMETER_CONF'"
Mehdi Abaakoukfc1b7782013-10-23 06:46:43 +0000230 fi
Piyush Masrani846609b2014-03-14 19:21:48 +0530231 if [[ "$VIRT_DRIVER" = 'vsphere' ]]; then
232 screen_it ceilometer-acompute "cd ; ceilometer-agent-compute --config-file $CEILOMETER_CONF"
233 fi
Mehdi Abaakouk6d4a9a82013-10-14 16:20:32 +0200234 screen_it ceilometer-acentral "cd ; ceilometer-agent-central --config-file $CEILOMETER_CONF"
Gordon Chung1c402282013-11-26 13:30:11 -0500235 screen_it ceilometer-anotification "cd ; ceilometer-agent-notification --config-file $CEILOMETER_CONF"
Mehdi Abaakouk6d4a9a82013-10-14 16:20:32 +0200236 screen_it ceilometer-collector "cd ; ceilometer-collector --config-file $CEILOMETER_CONF"
237 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 +0200238
Sean Dague7083b822014-02-28 20:16:20 -0500239 # only die on API if it was actually intended to be turned on
Sean Dagueb9a70352014-03-04 15:02:04 -0500240 if is_service_enabled ceilometer-api; then
Sean Dague7083b822014-02-28 20:16:20 -0500241 echo "Waiting for ceilometer-api to start..."
242 if ! timeout $SERVICE_TIMEOUT sh -c "while ! curl --noproxy '*' -s http://localhost:8777/v2/ >/dev/null; do sleep 1; done"; then
243 die $LINENO "ceilometer-api did not start"
244 fi
Mehdi Abaakouk1ed64cb2013-10-23 10:37:05 +0200245 fi
246
Mehdi Abaakouk6d4a9a82013-10-14 16:20:32 +0200247 screen_it ceilometer-alarm-notifier "cd ; ceilometer-alarm-notifier --config-file $CEILOMETER_CONF"
248 screen_it ceilometer-alarm-evaluator "cd ; ceilometer-alarm-evaluator --config-file $CEILOMETER_CONF"
John H. Tran93361642012-07-26 11:22:05 -0700249}
Dean Troyer7903b792012-09-13 17:16:12 -0500250
Dean Troyer699a29f2012-09-10 14:10:27 -0500251# stop_ceilometer() - Stop running processes
Ian Wienandaee18c72014-02-21 15:35:08 +1100252function stop_ceilometer {
Dean Troyer699a29f2012-09-10 14:10:27 -0500253 # Kill the ceilometer screen windows
Gordon Chung1c402282013-11-26 13:30:11 -0500254 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 -0500255 screen_stop $serv
Dean Troyer699a29f2012-09-10 14:10:27 -0500256 done
257}
258
Dean Troyercc6b4432013-04-08 15:38:03 -0500259
Dean Troyer7903b792012-09-13 17:16:12 -0500260# Restore xtrace
261$XTRACE
Sean Dague584d90e2013-03-29 14:34:53 -0400262
Adam Spiers6a5aa7c2013-10-24 11:27:02 +0100263# Tell emacs to use shell-script-mode
264## Local variables:
265## mode: shell-script
266## End: