blob: cd26d97dc48a568672db7879d989e3b0df7ae5ca [file] [log] [blame]
Sean Daguee263c822014-12-05 14:25:28 -05001#!/bin/bash
2#
Dean Troyer73f6f252012-09-17 11:22:21 -05003# lib/glance
Dean Troyer6d04fd72012-12-21 11:03:37 -06004# Functions to control the configuration and operation of the **Glance** service
Dean Troyer73f6f252012-09-17 11:22:21 -05005
6# Dependencies:
Adam Spiers6a5aa7c2013-10-24 11:27:02 +01007#
8# - ``functions`` file
9# - ``DEST``, ``DATA_DIR``, ``STACK_USER`` must be defined
10# - ``SERVICE_{TENANT_NAME|PASSWORD}`` must be defined
11# - ``SERVICE_HOST``
12# - ``KEYSTONE_TOKEN_FORMAT`` must be defined
Dean Troyer73f6f252012-09-17 11:22:21 -050013
14# ``stack.sh`` calls the entry points in this order:
15#
Adam Spiers6a5aa7c2013-10-24 11:27:02 +010016# - install_glance
17# - configure_glance
18# - init_glance
19# - start_glance
20# - stop_glance
21# - cleanup_glance
Dean Troyer73f6f252012-09-17 11:22:21 -050022
23# Save trace setting
Ian Wienand523f4882015-10-13 11:03:03 +110024_XTRACE_GLANCE=$(set +o | grep xtrace)
Dean Troyer73f6f252012-09-17 11:22:21 -050025set +o xtrace
26
27
28# Defaults
29# --------
30
Dean Troyer73f6f252012-09-17 11:22:21 -050031# Set up default directories
Sean Daguee08ab102014-11-13 17:09:28 -050032GITDIR["python-glanceclient"]=$DEST/python-glanceclient
Sean Dagueaecd1892014-11-19 15:19:51 -050033GITDIR["glance_store"]=$DEST/glance_store
Dean Troyer73f6f252012-09-17 11:22:21 -050034GLANCE_DIR=$DEST/glance
Dean Troyeraed60792015-02-17 15:38:16 -060035
36# Glance virtual environment
37if [[ ${USE_VENV} = True ]]; then
38 PROJECT_VENV["glance"]=${GLANCE_DIR}.venv
39 GLANCE_BIN_DIR=${PROJECT_VENV["glance"]}/bin
40else
41 GLANCE_BIN_DIR=$(get_python_exec_prefix)
42fi
43
Abhishek Kekane057aaa62020-07-29 07:37:16 +000044# Cinder for Glance
45USE_CINDER_FOR_GLANCE=$(trueorfalse False USE_CINDER_FOR_GLANCE)
46# GLANCE_CINDER_DEFAULT_BACKEND should be one of the values
47# from CINDER_ENABLED_BACKENDS
48GLANCE_CINDER_DEFAULT_BACKEND=${GLANCE_CINDER_DEFAULT_BACKEND:-lvmdriver-1}
49GLANCE_STORE_ROOTWRAP_BASE_DIR=/usr/local/etc/glance
50# NOTE (abhishekk): For opensuse data files are stored in different directory
51if is_opensuse; then
52 GLANCE_STORE_ROOTWRAP_BASE_DIR=/usr/etc/glance
53fi
Abhishek Kekane6f91da92019-10-17 09:02:41 +000054# Glance multi-store configuration
55# Boolean flag to enable multiple store configuration for glance
56GLANCE_ENABLE_MULTIPLE_STORES=$(trueorfalse False GLANCE_ENABLE_MULTIPLE_STORES)
57
58# Comma separated list for configuring multiple file stores of glance,
59# for example; GLANCE_MULTIPLE_FILE_STORES = fast,cheap,slow
60GLANCE_MULTIPLE_FILE_STORES=${GLANCE_MULTIPLE_FILE_STORES:-fast}
61
62# Default store/backend for glance, must be one of the store specified
63# in GLANCE_MULTIPLE_FILE_STORES option.
64GLANCE_DEFAULT_BACKEND=${GLANCE_DEFAULT_BACKEND:-fast}
65
Dean Troyer73f6f252012-09-17 11:22:21 -050066GLANCE_CACHE_DIR=${GLANCE_CACHE_DIR:=$DATA_DIR/glance/cache}
Abhishek Kekane6f91da92019-10-17 09:02:41 +000067
Dan Smith09eea0b2020-07-09 08:31:51 -070068# Full Glance functionality requires running in standalone mode. If we are
69# not in uwsgi mode, then we are standalone, otherwise allow separate control.
70if [[ "$WSGI_MODE" != "uwsgi" ]]; then
71 GLANCE_STANDALONE=True
72fi
Dan Smith155109d2020-07-24 06:49:01 -070073GLANCE_STANDALONE=${GLANCE_STANDALONE:-False}
Dan Smith09eea0b2020-07-09 08:31:51 -070074
Abhishek Kekane6f91da92019-10-17 09:02:41 +000075# File path for each store specified in GLANCE_MULTIPLE_FILE_STORES, the store
76# identifier will be appended to this path at runtime. If GLANCE_MULTIPLE_FILE_STORES
77# has fast,cheap specified then filepath will be generated like $DATA_DIR/glance/fast
78# and $DATA_DIR/glance/cheap.
79GLANCE_MULTISTORE_FILE_IMAGE_DIR=${GLANCE_MULTISTORE_FILE_IMAGE_DIR:=$DATA_DIR/glance}
Dean Troyer73f6f252012-09-17 11:22:21 -050080GLANCE_IMAGE_DIR=${GLANCE_IMAGE_DIR:=$DATA_DIR/glance/images}
Abhishek Kekane057aaa62020-07-29 07:37:16 +000081GLANCE_NFS_MOUNTPOINT=$GLANCE_IMAGE_DIR/mnt
Matthew Treinishfa898f52017-04-25 01:30:10 -040082GLANCE_LOCK_DIR=${GLANCE_LOCK_DIR:=$DATA_DIR/glance/locks}
Abhishek Kekane6f91da92019-10-17 09:02:41 +000083GLANCE_STAGING_DIR=${GLANCE_MULTISTORE_FILE_IMAGE_DIR:=$DATA_DIR/os_glance_staging_store}
84GLANCE_TASKS_DIR=${GLANCE_MULTISTORE_FILE_IMAGE_DIR:=$DATA_DIR/os_glance_tasks_store}
Dean Troyer73f6f252012-09-17 11:22:21 -050085
Abhishek Kekane73ad9762020-06-16 15:20:48 +000086GLANCE_USE_IMPORT_WORKFLOW=$(trueorfalse False GLANCE_USE_IMPORT_WORKFLOW)
Dan Smith4e916ae2021-04-26 08:52:23 -070087GLANCE_ENABLE_QUOTAS=$(trueorfalse True GLANCE_ENABLE_QUOTAS)
Abhishek Kekane73ad9762020-06-16 15:20:48 +000088
Ghanshyam Mann8c930492021-03-05 09:40:39 -060089# Flag to set the oslo_policy.enforce_scope. This is used to switch
90# the Image API policies to start checking the scope of token. By Default,
91# this flag is False.
92# For more detail: https://docs.openstack.org/oslo.policy/latest/configuration/index.html#oslo_policy.enforce_scope
93GLANCE_ENFORCE_SCOPE=$(trueorfalse False GLANCE_ENFORCE_SCOPE)
94
Dean Troyer73f6f252012-09-17 11:22:21 -050095GLANCE_CONF_DIR=${GLANCE_CONF_DIR:-/etc/glance}
Pawel Koniszewski76e39252014-09-06 07:06:46 -040096GLANCE_METADEF_DIR=$GLANCE_CONF_DIR/metadefs
Dean Troyer73f6f252012-09-17 11:22:21 -050097GLANCE_API_CONF=$GLANCE_CONF_DIR/glance-api.conf
Dean Troyer73f6f252012-09-17 11:22:21 -050098GLANCE_API_PASTE_INI=$GLANCE_CONF_DIR/glance-api-paste.ini
99GLANCE_CACHE_CONF=$GLANCE_CONF_DIR/glance-cache.conf
Dirk Mueller46d1ba62013-09-09 14:31:37 +0200100GLANCE_SCHEMA_JSON=$GLANCE_CONF_DIR/schema-image.json
Jamie Lennoxf4f01c62015-06-19 02:52:41 +0000101GLANCE_SWIFT_STORE_CONF=$GLANCE_CONF_DIR/glance-swift-store.conf
bhagyashris6a25fb92017-12-14 13:23:41 +0530102GLANCE_IMAGE_IMPORT_CONF=$GLANCE_CONF_DIR/glance-image-import.conf
Dean Troyer73f6f252012-09-17 11:22:21 -0500103
Sean Daguef3b2f4c2017-04-13 10:11:48 -0400104if is_service_enabled tls-proxy; then
Rob Crittenden18d47782014-03-19 17:47:42 -0400105 GLANCE_SERVICE_PROTOCOL="https"
106fi
107
Dean Troyer73f6f252012-09-17 11:22:21 -0500108# Glance connection info. Note the port must be specified.
Rob Crittenden18d47782014-03-19 17:47:42 -0400109GLANCE_SERVICE_HOST=${GLANCE_SERVICE_HOST:-$SERVICE_HOST}
Jens Harbottdc7b4292017-09-19 10:52:32 +0000110GLANCE_SERVICE_LISTEN_ADDRESS=${GLANCE_SERVICE_LISTEN_ADDRESS:-$(ipv6_unquote $SERVICE_LISTEN_ADDRESS)}
Rob Crittenden18d47782014-03-19 17:47:42 -0400111GLANCE_SERVICE_PORT=${GLANCE_SERVICE_PORT:-9292}
112GLANCE_SERVICE_PORT_INT=${GLANCE_SERVICE_PORT_INT:-19292}
113GLANCE_HOSTPORT=${GLANCE_HOSTPORT:-$GLANCE_SERVICE_HOST:$GLANCE_SERVICE_PORT}
114GLANCE_SERVICE_PROTOCOL=${GLANCE_SERVICE_PROTOCOL:-$SERVICE_PROTOCOL}
Matthew Treinish1fa65362017-06-23 22:32:37 +0000115GLANCE_UWSGI=$GLANCE_BIN_DIR/glance-wsgi-api
Jeremy Liu2f7df512017-07-12 10:09:48 +0800116GLANCE_UWSGI_CONF=$GLANCE_CONF_DIR/glance-uwsgi.ini
Julia Kreger5a642452021-07-19 07:01:29 -0700117
118# Glance default limit for Devstack
119GLANCE_LIMIT_IMAGE_SIZE_TOTAL=${GLANCE_LIMIT_IMAGE_SIZE_TOTAL:-1000}
120
Matthew Treinish1fa65362017-06-23 22:32:37 +0000121# If wsgi mode is uwsgi run glance under uwsgi, else default to eventlet
122# TODO(mtreinish): Remove the eventlet path here and in all the similar
123# conditionals below after the Pike release
124if [[ "$WSGI_MODE" == "uwsgi" ]]; then
125 GLANCE_URL="$GLANCE_SERVICE_PROTOCOL://$GLANCE_SERVICE_HOST/image"
126else
127 GLANCE_URL="$GLANCE_SERVICE_PROTOCOL://$GLANCE_HOSTPORT"
128fi
Dean Troyer73f6f252012-09-17 11:22:21 -0500129
Dean Troyercc6b4432013-04-08 15:38:03 -0500130# Functions
131# ---------
Dean Troyer73f6f252012-09-17 11:22:21 -0500132
Dean Troyere4fa7212014-01-15 15:04:49 -0600133# Test if any Glance services are enabled
134# is_glance_enabled
135function is_glance_enabled {
Clark Boylan902158b2017-05-30 14:11:09 -0700136 [[ ,${DISABLED_SERVICES} =~ ,"glance" ]] && return 1
Dean Troyere4fa7212014-01-15 15:04:49 -0600137 [[ ,${ENABLED_SERVICES} =~ ,"g-" ]] && return 0
138 return 1
139}
140
Dean Troyer73f6f252012-09-17 11:22:21 -0500141# cleanup_glance() - Remove residual data files, anything left over from previous
142# runs that a clean run would need to clean up
Ian Wienandaee18c72014-02-21 15:35:08 +1100143function cleanup_glance {
Dan Smith61b4fbf2021-03-09 08:05:37 -0800144 # delete image files (glance) and all of the glance-remote temporary
145 # storage
146 sudo rm -rf $GLANCE_CACHE_DIR $GLANCE_IMAGE_DIR "${DATA_DIR}/glance-remote"
Abhishek Kekane6f91da92019-10-17 09:02:41 +0000147
148 # Cleanup multiple stores directories
149 if [[ "$GLANCE_ENABLE_MULTIPLE_STORES" == "True" ]]; then
150 local store file_dir
151 for store in $(echo $GLANCE_MULTIPLE_FILE_STORES | tr "," "\n"); do
152 file_dir="${GLANCE_MULTISTORE_FILE_IMAGE_DIR}/${store}/"
153 sudo rm -rf $file_dir
154 done
155
156 # Cleanup reserved stores directories
157 sudo rm -rf $GLANCE_STAGING_DIR $GLANCE_TASKS_DIR
158 fi
Dean Troyer73f6f252012-09-17 11:22:21 -0500159}
160
Abhishek Kekane057aaa62020-07-29 07:37:16 +0000161# Set multiple cinder store related config options for each of the cinder store
162#
163function configure_multiple_cinder_stores {
164
165 local be be_name be_type enabled_backends
166 for be in ${CINDER_ENABLED_BACKENDS//,/ }; do
167 be_type=${be%%:*}
168 be_name=${be##*:}
169 enabled_backends+="${be_name}:cinder,"
170
171 set_common_cinder_store_params $be_name
172 iniset $GLANCE_API_CONF $be_name cinder_volume_type ${be_name}
173 if [[ "$be_type" == "nfs" ]]; then
174 mkdir -p "$GLANCE_NFS_MOUNTPOINT"
175 iniset $GLANCE_API_CONF $be_name cinder_mount_point_base "$GLANCE_NFS_MOUNTPOINT"
176 fi
177 done
178 iniset $GLANCE_API_CONF DEFAULT enabled_backends ${enabled_backends::-1}
179 iniset $GLANCE_API_CONF glance_store default_backend $GLANCE_CINDER_DEFAULT_BACKEND
180}
181
182# Set common cinder store options to given config section
183#
184# Arguments:
185# config_section
186#
187function set_common_cinder_store_params {
188 local config_section="$1"
189 iniset $GLANCE_API_CONF $config_section cinder_store_auth_address $KEYSTONE_SERVICE_URI_V3
190 iniset $GLANCE_API_CONF $config_section cinder_store_user_name glance
191 iniset $GLANCE_API_CONF $config_section cinder_store_password $SERVICE_PASSWORD
192 iniset $GLANCE_API_CONF $config_section cinder_store_project_name $SERVICE_PROJECT_NAME
193}
194
195# Configure multiple file stores options for each file store
196#
197# Arguments:
198#
199function configure_multiple_file_stores {
200 local store enabled_backends
201 enabled_backends=""
202 for store in $(echo $GLANCE_MULTIPLE_FILE_STORES | tr "," "\n"); do
203 enabled_backends+="${store}:file,"
204 done
205 iniset $GLANCE_API_CONF DEFAULT enabled_backends ${enabled_backends::-1}
206
207 # Glance multiple store Store specific configs
208 iniset $GLANCE_API_CONF glance_store default_backend $GLANCE_DEFAULT_BACKEND
209 local store
210 for store in $(echo $glance_multiple_file_stores | tr "," "\n"); do
211 iniset $GLANCE_API_CONF $store filesystem_store_datadir "${GLANCE_MULTISTORE_FILE_IMAGE_DIR}/${store}/"
212 done
213}
214
215# Set reserved stores for glance
216function configure_reserved_stores {
217 iniset $GLANCE_API_CONF os_glance_staging_store filesystem_store_datadir "${GLANCE_MULTISTORE_FILE_IMAGE_DIR}/os_glance_staging_store/"
218 iniset $GLANCE_API_CONF os_glance_tasks_store filesystem_store_datadir "${GLANCE_MULTISTORE_FILE_IMAGE_DIR}/os_glance_tasks_store/"
219}
220
221# Copy rootwrap file from glance_store/etc/glance to /etc/glance
222#
223# Arguments:
224# source_path Source path to copy rootwrap files from
225#
226function copy_rootwrap {
227 local source_path="$1"
228 # Make glance configuration directory if it is not exists
229 sudo install -d -o $STACK_USER $GLANCE_CONF_DIR
230 cp -r $source_path/rootwrap.* $GLANCE_CONF_DIR/
231}
232
233# Set glance_store related config options
234#
235# Arguments:
236# USE_CINDER_FOR_GLANCE
237# GLANCE_ENABLE_MULTIPLE_STORES
238#
239function configure_glance_store {
240 local use_cinder_for_glance="$1"
241 local glance_enable_multiple_stores="$2"
242 local be
243
244 if [[ "$glance_enable_multiple_stores" == "False" ]]; then
245 # Configure traditional glance_store
246 if [[ "$use_cinder_for_glance" == "True" ]]; then
247 # set common glance_store parameters
248 iniset $GLANCE_API_CONF glance_store stores "cinder,file,http"
249 iniset $GLANCE_API_CONF glance_store default_store cinder
250
251 # set cinder related store parameters
252 set_common_cinder_store_params glance_store
253 # set nfs mount_point dir
254 for be in ${CINDER_ENABLED_BACKENDS//,/ }; do
255 local be_name=${be##*:}
256 if [[ "$be_name" == "nfs" ]]; then
257 mkdir -p $GLANCE_NFS_MOUNTPOINT
258 iniset $GLANCE_API_CONF glance_store cinder_mount_point_base $GLANCE_NFS_MOUNTPOINT
259 fi
260 done
261 fi
262 # Store specific configs
263 iniset $GLANCE_API_CONF glance_store filesystem_store_datadir $GLANCE_IMAGE_DIR/
264 else
265 if [[ "$use_cinder_for_glance" == "True" ]]; then
266 # Configure multiple cinder stores for glance
267 configure_multiple_cinder_stores
268 else
269 # Configure multiple file stores for glance
270 configure_multiple_file_stores
271 fi
272 # Configure reserved stores
273 configure_reserved_stores
274 fi
275}
276
Dan Smith4e916ae2021-04-26 08:52:23 -0700277function configure_glance_quotas {
278
279 # NOTE(danms): We need to have some of the OS_ things unset in
280 # order to use system scope, which is required for creating these
281 # limits. This is a hack, but I dunno how else to get osc to use
282 # system scope.
283
284 bash -c "unset OS_USERNAME OS_TENANT_NAME OS_PROJECT_NAME;
285 openstack --os-cloud devstack-system-admin registered limit create \
Julia Kreger5a642452021-07-19 07:01:29 -0700286 --service glance --default-limit $GLANCE_LIMIT_IMAGE_SIZE_TOTAL \
287 --region $REGION_NAME image_size_total; \
Dan Smith4e916ae2021-04-26 08:52:23 -0700288 openstack --os-cloud devstack-system-admin registered limit create \
Julia Kreger5a642452021-07-19 07:01:29 -0700289 --service glance --default-limit $GLANCE_LIMIT_IMAGE_SIZE_TOTAL \
290 --region $REGION_NAME image_stage_total; \
Dan Smith4e916ae2021-04-26 08:52:23 -0700291 openstack --os-cloud devstack-system-admin registered limit create \
292 --service glance --default-limit 100 --region $REGION_NAME \
293 image_count_total; \
294 openstack --os-cloud devstack-system-admin registered limit create \
295 --service glance --default-limit 100 --region $REGION_NAME \
296 image_count_uploading"
297
298 # Tell glance to use these limits
299 iniset $GLANCE_API_CONF DEFAULT use_keystone_limits True
300
301 # Configure oslo_limit so it can talk to keystone
302 iniset $GLANCE_API_CONF oslo_limit user_domain_name $SERVICE_DOMAIN_NAME
303 iniset $GLANCE_API_CONF oslo_limit password $SERVICE_PASSWORD
304 iniset $GLANCE_API_CONF oslo_limit username glance
305 iniset $GLANCE_API_CONF oslo_limit auth_type password
306 iniset $GLANCE_API_CONF oslo_limit auth_url $KEYSTONE_SERVICE_URI
307 iniset $GLANCE_API_CONF oslo_limit system_scope "'all'"
308 iniset $GLANCE_API_CONF oslo_limit endpoint_id \
309 $(openstack endpoint list --service glance -f value -c ID)
310
311 # Allow the glance service user to read quotas
312 openstack role add --user glance --user-domain Default --system all \
313 reader
314}
315
Dean Troyer73f6f252012-09-17 11:22:21 -0500316# configure_glance() - Set config files, create data dirs, etc
Ian Wienandaee18c72014-02-21 15:35:08 +1100317function configure_glance {
Dean Troyer8421c2b2015-03-16 13:52:19 -0500318 sudo install -d -o $STACK_USER $GLANCE_CONF_DIR $GLANCE_METADEF_DIR
Pawel Koniszewski76e39252014-09-06 07:06:46 -0400319
Abhishek Kekane0ae57872020-02-17 06:11:15 +0000320 # Set non-default configuration options for the API server
Ian Wienandada886d2015-10-07 14:06:26 +1100321 local dburl
322 dburl=`database_connection_url glance`
Dean Troyer73f6f252012-09-17 11:22:21 -0500323
Ben Nemec03997942013-08-10 09:56:16 -0500324 iniset $GLANCE_API_CONF DEFAULT debug $ENABLE_DEBUG_LOG_LEVEL
Jordan Pittierceca15d2015-06-19 11:46:36 +0200325 iniset $GLANCE_API_CONF database connection $dburl
Dean Troyer73f6f252012-09-17 11:22:21 -0500326 iniset $GLANCE_API_CONF DEFAULT use_syslog $SYSLOG
Dean Troyer73f6f252012-09-17 11:22:21 -0500327 iniset $GLANCE_API_CONF DEFAULT image_cache_dir $GLANCE_CACHE_DIR/
ZhongShengping5fe60c12019-04-30 10:12:51 +0800328 iniset $GLANCE_API_CONF oslo_concurrency lock_path $GLANCE_LOCK_DIR
Dean Troyer73f6f252012-09-17 11:22:21 -0500329 iniset $GLANCE_API_CONF paste_deploy flavor keystone+cachemanagement
Dirk Mueller8ab64b32017-11-17 19:52:29 +0100330 configure_keystone_authtoken_middleware $GLANCE_API_CONF glance
Matt Riedemann45da7772017-03-05 13:07:39 -0500331 iniset $GLANCE_API_CONF oslo_messaging_notifications driver messagingv2
Brant Knudson2dd110c2015-03-14 12:39:14 -0500332 iniset_rpc_backend glance $GLANCE_API_CONF
Evgeny Antyshev19354582014-11-24 14:20:35 +0400333 if [ "$VIRT_DRIVER" = 'libvirt' ] && [ "$LIBVIRT_TYPE" = 'parallels' ]; then
334 iniset $GLANCE_API_CONF DEFAULT disk_formats "ami,ari,aki,vhd,vmdk,raw,qcow2,vdi,iso,ploop"
335 fi
Dean Troyer73f6f252012-09-17 11:22:21 -0500336
Abhishek Kekane057aaa62020-07-29 07:37:16 +0000337 # Configure glance_store
338 configure_glance_store $USE_CINDER_FOR_GLANCE $GLANCE_ENABLE_MULTIPLE_STORES
Flavio Percocofe65e2d2014-09-03 11:51:00 +0200339
Timur Sufieva44dd9a2016-04-29 14:08:51 +0300340 # CORS feature support - to allow calls from Horizon by default
341 if [ -n "$GLANCE_CORS_ALLOWED_ORIGIN" ]; then
342 iniset $GLANCE_API_CONF cors allowed_origin "$GLANCE_CORS_ALLOWED_ORIGIN"
343 else
344 iniset $GLANCE_API_CONF cors allowed_origin "http://$SERVICE_HOST"
345 fi
346
Abhishek Kekane6f91da92019-10-17 09:02:41 +0000347 # No multiple stores for swift yet
Abhishek Kekane057aaa62020-07-29 07:37:16 +0000348 if [[ "$GLANCE_ENABLE_MULTIPLE_STORES" == "False" ]]; then
349 # Store the images in swift if enabled.
350 if is_service_enabled s-proxy; then
351 iniset $GLANCE_API_CONF glance_store default_store swift
352 iniset $GLANCE_API_CONF glance_store swift_store_create_container_on_put True
Jamie Lennoxf4f01c62015-06-19 02:52:41 +0000353
Abhishek Kekane057aaa62020-07-29 07:37:16 +0000354 iniset $GLANCE_API_CONF glance_store swift_store_config_file $GLANCE_SWIFT_STORE_CONF
355 iniset $GLANCE_API_CONF glance_store default_swift_reference ref1
356 iniset $GLANCE_API_CONF glance_store stores "file, http, swift"
357 if is_service_enabled tls-proxy; then
358 iniset $GLANCE_API_CONF glance_store swift_store_cacert $SSL_BUNDLE_FILE
359 fi
360 iniset $GLANCE_API_CONF DEFAULT graceful_shutdown_timeout "$SERVICE_GRACEFUL_SHUTDOWN_TIMEOUT"
361
362 iniset $GLANCE_SWIFT_STORE_CONF ref1 user $SERVICE_PROJECT_NAME:glance-swift
363
364 iniset $GLANCE_SWIFT_STORE_CONF ref1 key $SERVICE_PASSWORD
365 iniset $GLANCE_SWIFT_STORE_CONF ref1 auth_address $KEYSTONE_SERVICE_URI/v3
366 iniset $GLANCE_SWIFT_STORE_CONF ref1 auth_version 3
Vladislav Kuzmin9cbd02d2020-05-20 12:14:04 +0400367 fi
Dean Troyerc77b9322013-03-29 10:51:01 -0500368 fi
369
Matthew Treinish1fa65362017-06-23 22:32:37 +0000370 # We need to tell glance what it's public endpoint is so that the version
371 # discovery document will be correct
372 iniset $GLANCE_API_CONF DEFAULT public_endpoint $GLANCE_URL
373
Rob Crittenden18d47782014-03-19 17:47:42 -0400374 if is_service_enabled tls-proxy; then
375 iniset $GLANCE_API_CONF DEFAULT bind_port $GLANCE_SERVICE_PORT_INT
Jens Harbott32c00892019-04-10 10:33:39 +0000376 iniset $GLANCE_API_CONF keystone_authtoken identity_uri $KEYSTONE_SERVICE_URI
Rob Crittenden18d47782014-03-19 17:47:42 -0400377 fi
378
Louis Taylor701276a2015-02-11 19:34:09 +0000379 # Format logging
Sean Dague9751be62016-04-05 12:08:57 -0400380 setup_logging $GLANCE_API_CONF
Louis Taylor701276a2015-02-11 19:34:09 +0000381
Dean Troyer73f6f252012-09-17 11:22:21 -0500382 cp -p $GLANCE_DIR/etc/glance-api-paste.ini $GLANCE_API_PASTE_INI
383
Brian Rosmaita44a19b42017-12-11 18:07:50 -0500384 # Set non-default configuration options for the glance-cache
Ben Nemec03997942013-08-10 09:56:16 -0500385 iniset $GLANCE_CACHE_CONF DEFAULT debug $ENABLE_DEBUG_LOG_LEVEL
Dean Troyer73f6f252012-09-17 11:22:21 -0500386 iniset $GLANCE_CACHE_CONF DEFAULT use_syslog $SYSLOG
Dean Troyer73f6f252012-09-17 11:22:21 -0500387 iniset $GLANCE_CACHE_CONF DEFAULT image_cache_dir $GLANCE_CACHE_DIR/
Jens Harbott32c00892019-04-10 10:33:39 +0000388 iniset $GLANCE_CACHE_CONF DEFAULT auth_url $KEYSTONE_SERVICE_URI
Sean Dague7580a0c2016-02-17 06:23:36 -0500389 iniset $GLANCE_CACHE_CONF DEFAULT admin_tenant_name $SERVICE_PROJECT_NAME
Dean Troyer73f6f252012-09-17 11:22:21 -0500390 iniset $GLANCE_CACHE_CONF DEFAULT admin_user glance
Dean Troyer73f6f252012-09-17 11:22:21 -0500391 iniset $GLANCE_CACHE_CONF DEFAULT admin_password $SERVICE_PASSWORD
392
Flavio Percocofe65e2d2014-09-03 11:51:00 +0200393 # Store specific confs
Flavio Percocofe65e2d2014-09-03 11:51:00 +0200394 iniset $GLANCE_CACHE_CONF glance_store filesystem_store_datadir $GLANCE_IMAGE_DIR/
395
bhagyashris6a25fb92017-12-14 13:23:41 +0530396 # Set default configuration options for the glance-image-import
397 iniset $GLANCE_IMAGE_IMPORT_CONF image_import_opts image_import_plugins []
398 iniset $GLANCE_IMAGE_IMPORT_CONF inject_metadata_properties ignore_user_roles admin
399 iniset $GLANCE_IMAGE_IMPORT_CONF inject_metadata_properties inject
400
Dirk Mueller46d1ba62013-09-09 14:31:37 +0200401 cp -p $GLANCE_DIR/etc/schema-image.json $GLANCE_SCHEMA_JSON
Pawel Koniszewski76e39252014-09-06 07:06:46 -0400402
403 cp -p $GLANCE_DIR/etc/metadefs/*.json $GLANCE_METADEF_DIR
Rob Crittenden18d47782014-03-19 17:47:42 -0400404
Sean Daguef3b2f4c2017-04-13 10:11:48 -0400405 if is_service_enabled tls-proxy; then
Rob Crittenden18d47782014-03-19 17:47:42 -0400406 CINDER_SERVICE_HOST=${CINDER_SERVICE_HOST:-$SERVICE_HOST}
407 CINDER_SERVICE_PORT=${CINDER_SERVICE_PORT:-8776}
408
Brian Rosmaitab43810a2019-02-07 16:46:49 -0500409 iniset $GLANCE_API_CONF DEFAULT cinder_endpoint_template "https://$CINDER_SERVICE_HOST:$CINDER_SERVICE_PORT/v3/%(project_id)s"
410 iniset $GLANCE_CACHE_CONF DEFAULT cinder_endpoint_template "https://$CINDER_SERVICE_HOST:$CINDER_SERVICE_PORT/v3/%(project_id)s"
Rob Crittenden18d47782014-03-19 17:47:42 -0400411 fi
Matthew Treinish1fa65362017-06-23 22:32:37 +0000412
Dan Smith09eea0b2020-07-09 08:31:51 -0700413 if [[ "$GLANCE_STANDALONE" == False ]]; then
Matthew Treinish1fa65362017-06-23 22:32:37 +0000414 write_local_uwsgi_http_config "$GLANCE_UWSGI_CONF" "$GLANCE_UWSGI" "/image"
Dan Smith802259a2021-01-12 22:55:57 +0000415 # Grab our uwsgi listen address and use that to fill out our
416 # worker_self_reference_url config
417 iniset $GLANCE_API_CONF DEFAULT worker_self_reference_url \
418 $(awk '-F= ' '/^http-socket/ { print "http://"$2}' \
419 $GLANCE_UWSGI_CONF)
Matthew Treinish1fa65362017-06-23 22:32:37 +0000420 else
Dan Smith09eea0b2020-07-09 08:31:51 -0700421 write_local_proxy_http_config glance "http://$GLANCE_SERVICE_HOST:$GLANCE_SERVICE_PORT_INT" "/image"
Matthew Treinish1fa65362017-06-23 22:32:37 +0000422 iniset $GLANCE_API_CONF DEFAULT bind_host $GLANCE_SERVICE_LISTEN_ADDRESS
Dan Smithfcbf3e92020-07-17 10:14:14 -0700423 iniset $GLANCE_API_CONF DEFAULT bind_port $GLANCE_SERVICE_PORT_INT
Matthew Treinish1fa65362017-06-23 22:32:37 +0000424 iniset $GLANCE_API_CONF DEFAULT workers "$API_WORKERS"
425 fi
Ghanshyam Mann8c930492021-03-05 09:40:39 -0600426
427 if [[ "$GLANCE_ENFORCE_SCOPE" == True ]] ; then
428 iniset $GLANCE_API_CONF oslo_policy enforce_scope true
429 iniset $GLANCE_API_CONF oslo_policy enforce_new_defaults true
430 iniset $GLANCE_API_CONF DEFAULT enforce_secure_rbac true
431 fi
Dean Troyer73f6f252012-09-17 11:22:21 -0500432}
433
Dean Troyer42a59c22014-03-03 14:31:29 -0600434# create_glance_accounts() - Set up common required glance accounts
435
Wayne Okumadd622932015-03-31 00:28:39 -0700436# Project User Roles
437# ---------------------------------------------------------------------
Sean Dague7580a0c2016-02-17 06:23:36 -0500438# SERVICE_PROJECT_NAME glance service
439# SERVICE_PROJECT_NAME glance-swift ResellerAdmin (if Swift is enabled)
440# SERVICE_PROJECT_NAME glance-search search (if Search is enabled)
Dean Troyer42a59c22014-03-03 14:31:29 -0600441
442function create_glance_accounts {
443 if is_service_enabled g-api; then
Bartosz Górski0abde392014-02-28 14:15:19 +0100444
Jamie Lennox85ff5322015-01-28 14:28:01 +1000445 create_service_user "glance"
Bartosz Górski0abde392014-02-28 14:15:19 +0100446
Dean Troyer42a59c22014-03-03 14:31:29 -0600447 # required for swift access
448 if is_service_enabled s-proxy; then
Jamie Lennoxcbcbd8f2016-01-21 16:08:14 -0600449 create_service_user "glance-swift" "ResellerAdmin"
Dean Troyer42a59c22014-03-03 14:31:29 -0600450 fi
Bartosz Górski0abde392014-02-28 14:15:19 +0100451
Sean Dague985e9582016-02-10 07:25:24 -0500452 get_or_create_service "glance" "image" "Glance Image Service"
Matt Riedemannae4578b2016-04-23 01:45:40 +0000453 get_or_create_endpoint \
Sean Dague985e9582016-02-10 07:25:24 -0500454 "image" \
455 "$REGION_NAME" \
Matthew Treinish1fa65362017-06-23 22:32:37 +0000456 "$GLANCE_URL"
Jens Rosenboom890342e2016-09-13 22:41:41 +0200457
458 # Note(frickler): Crude workaround for https://bugs.launchpad.net/glance-store/+bug/1620999
459 service_domain_id=$(get_or_create_domain $SERVICE_DOMAIN_NAME)
460 iniset $GLANCE_SWIFT_STORE_CONF ref1 project_domain_id $service_domain_id
461 iniset $GLANCE_SWIFT_STORE_CONF ref1 user_domain_id $service_domain_id
Dan Smith4e916ae2021-04-26 08:52:23 -0700462
463 if [[ "$GLANCE_ENABLE_QUOTAS" = True ]]; then
464 configure_glance_quotas
465 fi
466
Dean Troyer42a59c22014-03-03 14:31:29 -0600467 fi
468}
469
Dean Troyer73f6f252012-09-17 11:22:21 -0500470# init_glance() - Initialize databases, etc.
Ian Wienandaee18c72014-02-21 15:35:08 +1100471function init_glance {
Dean Troyer73f6f252012-09-17 11:22:21 -0500472 # Delete existing images
473 rm -rf $GLANCE_IMAGE_DIR
474 mkdir -p $GLANCE_IMAGE_DIR
475
Radosław Piliszek09e860f2020-01-19 12:41:14 +0100476 # (Re)create glance database
477 recreate_database glance
Dean Troyer73f6f252012-09-17 11:22:21 -0500478
Radosław Piliszek09e860f2020-01-19 12:41:14 +0100479 time_start "dbsync"
480 # Migrate glance database
481 $GLANCE_BIN_DIR/glance-manage --config-file $GLANCE_CONF_DIR/glance-api.conf db_sync
Dean Troyerbc071bc2012-10-01 14:06:44 -0500482
Radosław Piliszek09e860f2020-01-19 12:41:14 +0100483 # Load metadata definitions
484 $GLANCE_BIN_DIR/glance-manage --config-file $GLANCE_CONF_DIR/glance-api.conf db_load_metadefs
485 time_stop "dbsync"
Dean Troyer73f6f252012-09-17 11:22:21 -0500486}
487
488# install_glanceclient() - Collect source and prepare
Ian Wienandaee18c72014-02-21 15:35:08 +1100489function install_glanceclient {
Sean Daguee08ab102014-11-13 17:09:28 -0500490 if use_library_from_git "python-glanceclient"; then
491 git_clone_by_name "python-glanceclient"
492 setup_dev_lib "python-glanceclient"
Louis Taylor8df690c2014-11-20 13:09:03 +0000493 sudo install -D -m 0644 -o $STACK_USER {${GITDIR["python-glanceclient"]}/tools/,/etc/bash_completion.d/}glance.bash_completion
Sean Dague5cb19062014-11-01 01:37:45 +0100494 fi
Dean Troyer73f6f252012-09-17 11:22:21 -0500495}
496
497# install_glance() - Collect source and prepare
Ian Wienandaee18c72014-02-21 15:35:08 +1100498function install_glance {
Radosław Piliszekbe263062020-03-30 09:56:53 +0200499 local glance_store_extras=()
500
501 if is_service_enabled cinder; then
502 glance_store_extras=("cinder" "${glance_store_extras[@]}")
503 fi
504
505 if is_service_enabled swift; then
506 glance_store_extras=("swift" "${glance_store_extras[@]}")
507 fi
508
Flavio Percoco4f78f8f2014-09-09 09:37:42 +0200509 # Install glance_store from git so we make sure we're testing
510 # the latest code.
Sean Dagueee5ae7b2014-11-13 13:23:27 -0500511 if use_library_from_git "glance_store"; then
512 git_clone_by_name "glance_store"
Radosław Piliszekbe263062020-03-30 09:56:53 +0200513 setup_dev_lib "glance_store" $(join_extras "${glance_store_extras[@]}")
Abhishek Kekane057aaa62020-07-29 07:37:16 +0000514 copy_rootwrap ${DEST}/glance_store/etc/glance
Radosław Piliszekbe263062020-03-30 09:56:53 +0200515 else
516 # we still need to pass extras
517 pip_install_gr_extras glance-store $(join_extras "${glance_store_extras[@]}")
Abhishek Kekane057aaa62020-07-29 07:37:16 +0000518 copy_rootwrap $GLANCE_STORE_ROOTWRAP_BASE_DIR
Sean Dagueee5ae7b2014-11-13 13:23:27 -0500519 fi
Flavio Percoco4f78f8f2014-09-09 09:37:42 +0200520
Dean Troyer73f6f252012-09-17 11:22:21 -0500521 git_clone $GLANCE_REPO $GLANCE_DIR $GLANCE_BRANCH
Wayne Okumadd622932015-03-31 00:28:39 -0700522
Wayne Okumadd622932015-03-31 00:28:39 -0700523 setup_develop $GLANCE_DIR
Dean Troyer73f6f252012-09-17 11:22:21 -0500524}
525
Dan Smith802259a2021-01-12 22:55:57 +0000526# glance_remote_conf() - Return the path to an alternate config file for
527# the remote glance clone
528function glance_remote_conf {
Dan Smith61b4fbf2021-03-09 08:05:37 -0800529 echo $(dirname "${GLANCE_CONF_DIR}")/glance-remote/$(basename "$1")
Dan Smith802259a2021-01-12 22:55:57 +0000530}
531
532# start_glance_remote_clone() - Clone the regular glance api worker
533function start_glance_remote_clone {
Dan Smith61b4fbf2021-03-09 08:05:37 -0800534 local glance_remote_conf_dir glance_remote_port remote_data
535 local glance_remote_uwsgi
Dan Smith802259a2021-01-12 22:55:57 +0000536
Dan Smith61b4fbf2021-03-09 08:05:37 -0800537 glance_remote_conf_dir="$(glance_remote_conf "")"
Dan Smith802259a2021-01-12 22:55:57 +0000538 glance_remote_port=$(get_random_port)
Dan Smith61b4fbf2021-03-09 08:05:37 -0800539 glance_remote_uwsgi="$(glance_remote_conf $GLANCE_UWSGI_CONF)"
Dan Smith802259a2021-01-12 22:55:57 +0000540
541 # Clone the existing ready-to-go glance-api setup
Dan Smith61b4fbf2021-03-09 08:05:37 -0800542 sudo rm -Rf "$glance_remote_conf_dir"
543 sudo cp -r "$GLANCE_CONF_DIR" "$glance_remote_conf_dir"
544 sudo chown $STACK_USER -R "$glance_remote_conf_dir"
Dan Smith802259a2021-01-12 22:55:57 +0000545
546 # Point this worker at different data dirs
547 remote_data="${DATA_DIR}/glance-remote"
548 mkdir -p $remote_data/os_glance_tasks_store \
Dan Smith61b4fbf2021-03-09 08:05:37 -0800549 "${remote_data}/os_glance_staging_store"
550 iniset $(glance_remote_conf "$GLANCE_API_CONF") os_glance_staging_store \
551 filesystem_store_datadir "${remote_data}/os_glance_staging_store"
552 iniset $(glance_remote_conf "$GLANCE_API_CONF") os_glance_tasks_store \
553 filesystem_store_datadir "${remote_data}/os_glance_tasks_store"
Dan Smith802259a2021-01-12 22:55:57 +0000554
555 # Change our uwsgi to our new port
556 sed -ri "s/^(http-socket.*):[0-9]+/\1:$glance_remote_port/" \
Dan Smith61b4fbf2021-03-09 08:05:37 -0800557 "$glance_remote_uwsgi"
Dan Smith802259a2021-01-12 22:55:57 +0000558
559 # Update the self-reference url with our new port
560 iniset $(glance_remote_conf $GLANCE_API_CONF) DEFAULT \
561 worker_self_reference_url \
562 $(awk '-F= ' '/^http-socket/ { print "http://"$2 }' \
Dan Smith61b4fbf2021-03-09 08:05:37 -0800563 "$glance_remote_uwsgi")
Dan Smith802259a2021-01-12 22:55:57 +0000564
565 # We need to create the systemd service for the clone, but then
566 # change it to include an Environment line to point the WSGI app
567 # at the alternate config directory.
568 write_uwsgi_user_unit_file devstack@g-api-r.service "$(which uwsgi) \
569 --procname-prefix \
570 glance-api-remote \
Dan Smith61b4fbf2021-03-09 08:05:37 -0800571 --ini $glance_remote_uwsgi" \
Dan Smith802259a2021-01-12 22:55:57 +0000572 "" "$STACK_USER"
573 iniset -sudo ${SYSTEMD_DIR}/devstack@g-api-r.service \
Dan Smith61b4fbf2021-03-09 08:05:37 -0800574 "Service" "Environment" \
575 "OS_GLANCE_CONFIG_DIR=$glance_remote_conf_dir"
Dan Smith802259a2021-01-12 22:55:57 +0000576
577 # Reload and restart with the new config
578 $SYSTEMCTL daemon-reload
579 $SYSTEMCTL restart devstack@g-api-r
580
581 get_or_create_service glance_remote image_remote "Alternate glance"
582 get_or_create_endpoint image_remote $REGION_NAME \
583 $(awk '-F= ' '/^http-socket/ { print "http://"$2 }' \
Dan Smith61b4fbf2021-03-09 08:05:37 -0800584 $glance_remote_uwsgi)
Dan Smith802259a2021-01-12 22:55:57 +0000585}
586
Sean Dague0eebeb42017-08-30 14:16:58 -0400587# start_glance() - Start running processes
Ian Wienandaee18c72014-02-21 15:35:08 +1100588function start_glance {
Rob Crittenden18d47782014-03-19 17:47:42 -0400589 local service_protocol=$GLANCE_SERVICE_PROTOCOL
590 if is_service_enabled tls-proxy; then
Matthew Treinish1fa65362017-06-23 22:32:37 +0000591 if [[ "$WSGI_MODE" != "uwsgi" ]]; then
592 start_tls_proxy glance-service '*' $GLANCE_SERVICE_PORT $GLANCE_SERVICE_HOST $GLANCE_SERVICE_PORT_INT
593 fi
Rob Crittenden18d47782014-03-19 17:47:42 -0400594 fi
595
Dan Smith09eea0b2020-07-09 08:31:51 -0700596 if [[ "$GLANCE_STANDALONE" == False ]]; then
Ian Wienand312517d2018-06-22 22:23:29 +1000597 run_process g-api "$(which uwsgi) --procname-prefix glance-api --ini $GLANCE_UWSGI_CONF"
Matthew Treinish1fa65362017-06-23 22:32:37 +0000598 else
Brian Rosmaita96269d82018-12-17 10:38:42 -0500599 run_process g-api "$GLANCE_BIN_DIR/glance-api --config-dir=$GLANCE_CONF_DIR"
Matthew Treinish1fa65362017-06-23 22:32:37 +0000600 fi
Rob Crittenden18d47782014-03-19 17:47:42 -0400601
Dan Smith802259a2021-01-12 22:55:57 +0000602 if is_service_enabled g-api-r; then
603 echo "Starting the g-api-r clone service..."
604 start_glance_remote_clone
605 fi
606
Matthew Treinish1fa65362017-06-23 22:32:37 +0000607 echo "Waiting for g-api ($GLANCE_SERVICE_HOST) to start..."
608 if ! wait_for_service $SERVICE_TIMEOUT $GLANCE_URL; then
Sean Dague101b4242013-10-22 08:47:11 -0400609 die $LINENO "g-api did not start"
Dean Troyer73f6f252012-09-17 11:22:21 -0500610 fi
611}
612
Dean Troyer699a29f2012-09-10 14:10:27 -0500613# stop_glance() - Stop running processes
Ian Wienandaee18c72014-02-21 15:35:08 +1100614function stop_glance {
Chris Dent2f27a0e2014-09-09 13:46:02 +0100615 stop_process g-api
Dan Smith802259a2021-01-12 22:55:57 +0000616 stop_process g-api-r
Dean Troyer73f6f252012-09-17 11:22:21 -0500617}
618
619# Restore xtrace
Ian Wienand523f4882015-10-13 11:03:03 +1100620$_XTRACE_GLANCE
Sean Dague584d90e2013-03-29 14:34:53 -0400621
Adam Spiers6a5aa7c2013-10-24 11:27:02 +0100622# Tell emacs to use shell-script-mode
623## Local variables:
624## mode: shell-script
625## End: