Sean Dague | e263c82 | 2014-12-05 14:25:28 -0500 | [diff] [blame] | 1 | #!/bin/bash |
| 2 | # |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 3 | # lib/glance |
Dean Troyer | 6d04fd7 | 2012-12-21 11:03:37 -0600 | [diff] [blame] | 4 | # Functions to control the configuration and operation of the **Glance** service |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 5 | |
| 6 | # Dependencies: |
Adam Spiers | 6a5aa7c | 2013-10-24 11:27:02 +0100 | [diff] [blame] | 7 | # |
| 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 Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 13 | |
| 14 | # ``stack.sh`` calls the entry points in this order: |
| 15 | # |
Adam Spiers | 6a5aa7c | 2013-10-24 11:27:02 +0100 | [diff] [blame] | 16 | # - install_glance |
| 17 | # - configure_glance |
| 18 | # - init_glance |
| 19 | # - start_glance |
| 20 | # - stop_glance |
| 21 | # - cleanup_glance |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 22 | |
| 23 | # Save trace setting |
Ian Wienand | 523f488 | 2015-10-13 11:03:03 +1100 | [diff] [blame] | 24 | _XTRACE_GLANCE=$(set +o | grep xtrace) |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 25 | set +o xtrace |
| 26 | |
| 27 | |
| 28 | # Defaults |
| 29 | # -------- |
| 30 | |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 31 | # Set up default directories |
Sean Dague | e08ab10 | 2014-11-13 17:09:28 -0500 | [diff] [blame] | 32 | GITDIR["python-glanceclient"]=$DEST/python-glanceclient |
Sean Dague | aecd189 | 2014-11-19 15:19:51 -0500 | [diff] [blame] | 33 | GITDIR["glance_store"]=$DEST/glance_store |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 34 | GLANCE_DIR=$DEST/glance |
Dean Troyer | aed6079 | 2015-02-17 15:38:16 -0600 | [diff] [blame] | 35 | |
| 36 | # Glance virtual environment |
| 37 | if [[ ${USE_VENV} = True ]]; then |
| 38 | PROJECT_VENV["glance"]=${GLANCE_DIR}.venv |
| 39 | GLANCE_BIN_DIR=${PROJECT_VENV["glance"]}/bin |
| 40 | else |
| 41 | GLANCE_BIN_DIR=$(get_python_exec_prefix) |
| 42 | fi |
| 43 | |
Abhishek Kekane | b8cd9d1 | 2024-11-07 08:27:13 +0000 | [diff] [blame] | 44 | #S3 for Glance |
| 45 | GLANCE_USE_S3=$(trueorfalse False GLANCE_USE_S3) |
| 46 | GLANCE_S3_DEFAULT_BACKEND=${GLANCE_S3_DEFAULT_BACKEND:-s3_fast} |
| 47 | GLANCE_S3_BUCKET_ON_PUT=$(trueorfalse True GLANCE_S3_BUCKET_ON_PUT) |
| 48 | GLANCE_S3_BUCKET_NAME=${GLANCE_S3_BUCKET_NAME:-images} |
| 49 | |
Abhishek Kekane | 057aaa6 | 2020-07-29 07:37:16 +0000 | [diff] [blame] | 50 | # Cinder for Glance |
| 51 | USE_CINDER_FOR_GLANCE=$(trueorfalse False USE_CINDER_FOR_GLANCE) |
| 52 | # GLANCE_CINDER_DEFAULT_BACKEND should be one of the values |
| 53 | # from CINDER_ENABLED_BACKENDS |
| 54 | GLANCE_CINDER_DEFAULT_BACKEND=${GLANCE_CINDER_DEFAULT_BACKEND:-lvmdriver-1} |
| 55 | GLANCE_STORE_ROOTWRAP_BASE_DIR=/usr/local/etc/glance |
Clark Boylan | a40f9cb | 2018-04-04 14:02:30 -0700 | [diff] [blame] | 56 | if [[ "$GLOBAL_VENV" == "True" ]] ; then |
| 57 | GLANCE_STORE_ROOTWRAP_BASE_DIR=${DEVSTACK_VENV}/etc/glance |
| 58 | fi |
Brian Rosmaita | 6e9f7c2 | 2020-10-13 14:20:38 -0400 | [diff] [blame] | 59 | # When Cinder is used as a glance store, you can optionally configure cinder to |
| 60 | # optimize bootable volume creation by allowing volumes to be cloned directly |
| 61 | # in the backend instead of transferring data via Glance. To use this feature, |
| 62 | # set CINDER_ALLOWED_DIRECT_URL_SCHEMES for cinder.conf and enable |
| 63 | # GLANCE_SHOW_DIRECT_URL and/or GLANCE_SHOW_MULTIPLE_LOCATIONS for Glance. The |
| 64 | # default value for both of these is False, because for some backends they |
| 65 | # present a grave security risk (though not for Cinder, because all that's |
| 66 | # exposed is the volume_id where the image data is stored.) See OSSN-0065 for |
| 67 | # more information: https://wiki.openstack.org/wiki/OSSN/OSSN-0065 |
| 68 | GLANCE_SHOW_DIRECT_URL=$(trueorfalse False GLANCE_SHOW_DIRECT_URL) |
| 69 | GLANCE_SHOW_MULTIPLE_LOCATIONS=$(trueorfalse False GLANCE_SHOW_MULTIPLE_LOCATIONS) |
| 70 | |
Abhishek Kekane | 6f91da9 | 2019-10-17 09:02:41 +0000 | [diff] [blame] | 71 | # Glance multi-store configuration |
| 72 | # Boolean flag to enable multiple store configuration for glance |
| 73 | GLANCE_ENABLE_MULTIPLE_STORES=$(trueorfalse False GLANCE_ENABLE_MULTIPLE_STORES) |
| 74 | |
| 75 | # Comma separated list for configuring multiple file stores of glance, |
| 76 | # for example; GLANCE_MULTIPLE_FILE_STORES = fast,cheap,slow |
| 77 | GLANCE_MULTIPLE_FILE_STORES=${GLANCE_MULTIPLE_FILE_STORES:-fast} |
| 78 | |
| 79 | # Default store/backend for glance, must be one of the store specified |
| 80 | # in GLANCE_MULTIPLE_FILE_STORES option. |
| 81 | GLANCE_DEFAULT_BACKEND=${GLANCE_DEFAULT_BACKEND:-fast} |
| 82 | |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 83 | GLANCE_CACHE_DIR=${GLANCE_CACHE_DIR:=$DATA_DIR/glance/cache} |
Abhishek Kekane | d251d12 | 2024-01-29 18:20:06 +0000 | [diff] [blame] | 84 | GLANCE_CACHE_DRIVER=${GLANCE_CACHE_DRIVER:-centralized_db} |
Abhishek Kekane | 6f91da9 | 2019-10-17 09:02:41 +0000 | [diff] [blame] | 85 | |
Dan Smith | 09eea0b | 2020-07-09 08:31:51 -0700 | [diff] [blame] | 86 | # Full Glance functionality requires running in standalone mode. If we are |
| 87 | # not in uwsgi mode, then we are standalone, otherwise allow separate control. |
| 88 | if [[ "$WSGI_MODE" != "uwsgi" ]]; then |
| 89 | GLANCE_STANDALONE=True |
| 90 | fi |
Dan Smith | 155109d | 2020-07-24 06:49:01 -0700 | [diff] [blame] | 91 | GLANCE_STANDALONE=${GLANCE_STANDALONE:-False} |
Dan Smith | 09eea0b | 2020-07-09 08:31:51 -0700 | [diff] [blame] | 92 | |
Abhishek Kekane | 6f91da9 | 2019-10-17 09:02:41 +0000 | [diff] [blame] | 93 | # File path for each store specified in GLANCE_MULTIPLE_FILE_STORES, the store |
| 94 | # identifier will be appended to this path at runtime. If GLANCE_MULTIPLE_FILE_STORES |
| 95 | # has fast,cheap specified then filepath will be generated like $DATA_DIR/glance/fast |
| 96 | # and $DATA_DIR/glance/cheap. |
| 97 | GLANCE_MULTISTORE_FILE_IMAGE_DIR=${GLANCE_MULTISTORE_FILE_IMAGE_DIR:=$DATA_DIR/glance} |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 98 | GLANCE_IMAGE_DIR=${GLANCE_IMAGE_DIR:=$DATA_DIR/glance/images} |
Abhishek Kekane | 057aaa6 | 2020-07-29 07:37:16 +0000 | [diff] [blame] | 99 | GLANCE_NFS_MOUNTPOINT=$GLANCE_IMAGE_DIR/mnt |
Matthew Treinish | fa898f5 | 2017-04-25 01:30:10 -0400 | [diff] [blame] | 100 | GLANCE_LOCK_DIR=${GLANCE_LOCK_DIR:=$DATA_DIR/glance/locks} |
Abhishek Kekane | 6f91da9 | 2019-10-17 09:02:41 +0000 | [diff] [blame] | 101 | GLANCE_STAGING_DIR=${GLANCE_MULTISTORE_FILE_IMAGE_DIR:=$DATA_DIR/os_glance_staging_store} |
| 102 | GLANCE_TASKS_DIR=${GLANCE_MULTISTORE_FILE_IMAGE_DIR:=$DATA_DIR/os_glance_tasks_store} |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 103 | |
Abhishek Kekane | 73ad976 | 2020-06-16 15:20:48 +0000 | [diff] [blame] | 104 | GLANCE_USE_IMPORT_WORKFLOW=$(trueorfalse False GLANCE_USE_IMPORT_WORKFLOW) |
Dan Smith | 4e916ae | 2021-04-26 08:52:23 -0700 | [diff] [blame] | 105 | GLANCE_ENABLE_QUOTAS=$(trueorfalse True GLANCE_ENABLE_QUOTAS) |
Abhishek Kekane | 73ad976 | 2020-06-16 15:20:48 +0000 | [diff] [blame] | 106 | |
Ghanshyam Mann | 8c93049 | 2021-03-05 09:40:39 -0600 | [diff] [blame] | 107 | # Flag to set the oslo_policy.enforce_scope. This is used to switch |
Ghanshyam Mann | cb1ec18 | 2023-05-18 19:58:41 -0500 | [diff] [blame] | 108 | # This is used to disable the Image API policies scope and new defaults. |
| 109 | # By Default, it is True. |
Ghanshyam Mann | 8c93049 | 2021-03-05 09:40:39 -0600 | [diff] [blame] | 110 | # For more detail: https://docs.openstack.org/oslo.policy/latest/configuration/index.html#oslo_policy.enforce_scope |
Ghanshyam Mann | cb1ec18 | 2023-05-18 19:58:41 -0500 | [diff] [blame] | 111 | GLANCE_ENFORCE_SCOPE=$(trueorfalse True GLANCE_ENFORCE_SCOPE) |
Ghanshyam Mann | 8c93049 | 2021-03-05 09:40:39 -0600 | [diff] [blame] | 112 | |
Dan Smith | 803a7d4 | 2024-10-01 07:42:34 -0700 | [diff] [blame] | 113 | # Flag to disable image format inspection on upload |
| 114 | GLANCE_ENFORCE_IMAGE_FORMAT=$(trueorfalse True GLANCE_ENFORCE_IMAGE_FORMAT) |
| 115 | |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 116 | GLANCE_CONF_DIR=${GLANCE_CONF_DIR:-/etc/glance} |
Pawel Koniszewski | 76e3925 | 2014-09-06 07:06:46 -0400 | [diff] [blame] | 117 | GLANCE_METADEF_DIR=$GLANCE_CONF_DIR/metadefs |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 118 | GLANCE_API_CONF=$GLANCE_CONF_DIR/glance-api.conf |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 119 | GLANCE_API_PASTE_INI=$GLANCE_CONF_DIR/glance-api-paste.ini |
| 120 | GLANCE_CACHE_CONF=$GLANCE_CONF_DIR/glance-cache.conf |
Dirk Mueller | 46d1ba6 | 2013-09-09 14:31:37 +0200 | [diff] [blame] | 121 | GLANCE_SCHEMA_JSON=$GLANCE_CONF_DIR/schema-image.json |
Jamie Lennox | f4f01c6 | 2015-06-19 02:52:41 +0000 | [diff] [blame] | 122 | GLANCE_SWIFT_STORE_CONF=$GLANCE_CONF_DIR/glance-swift-store.conf |
bhagyashris | 6a25fb9 | 2017-12-14 13:23:41 +0530 | [diff] [blame] | 123 | GLANCE_IMAGE_IMPORT_CONF=$GLANCE_CONF_DIR/glance-image-import.conf |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 124 | |
Sean Dague | f3b2f4c | 2017-04-13 10:11:48 -0400 | [diff] [blame] | 125 | if is_service_enabled tls-proxy; then |
Rob Crittenden | 18d4778 | 2014-03-19 17:47:42 -0400 | [diff] [blame] | 126 | GLANCE_SERVICE_PROTOCOL="https" |
| 127 | fi |
| 128 | |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 129 | # Glance connection info. Note the port must be specified. |
Rob Crittenden | 18d4778 | 2014-03-19 17:47:42 -0400 | [diff] [blame] | 130 | GLANCE_SERVICE_HOST=${GLANCE_SERVICE_HOST:-$SERVICE_HOST} |
Jens Harbott | dc7b429 | 2017-09-19 10:52:32 +0000 | [diff] [blame] | 131 | GLANCE_SERVICE_LISTEN_ADDRESS=${GLANCE_SERVICE_LISTEN_ADDRESS:-$(ipv6_unquote $SERVICE_LISTEN_ADDRESS)} |
Rob Crittenden | 18d4778 | 2014-03-19 17:47:42 -0400 | [diff] [blame] | 132 | GLANCE_SERVICE_PORT=${GLANCE_SERVICE_PORT:-9292} |
| 133 | GLANCE_SERVICE_PORT_INT=${GLANCE_SERVICE_PORT_INT:-19292} |
| 134 | GLANCE_HOSTPORT=${GLANCE_HOSTPORT:-$GLANCE_SERVICE_HOST:$GLANCE_SERVICE_PORT} |
| 135 | GLANCE_SERVICE_PROTOCOL=${GLANCE_SERVICE_PROTOCOL:-$SERVICE_PROTOCOL} |
Stephen Finucane | 497b4fd | 2024-10-18 13:47:55 +0100 | [diff] [blame] | 136 | GLANCE_UWSGI=glance.wsgi.api:application |
Jeremy Liu | 2f7df51 | 2017-07-12 10:09:48 +0800 | [diff] [blame] | 137 | GLANCE_UWSGI_CONF=$GLANCE_CONF_DIR/glance-uwsgi.ini |
Julia Kreger | 5a64245 | 2021-07-19 07:01:29 -0700 | [diff] [blame] | 138 | |
| 139 | # Glance default limit for Devstack |
Rajat Dhasmana | 9a1cdbc | 2025-01-08 18:43:40 +0530 | [diff] [blame] | 140 | GLANCE_LIMIT_IMAGE_SIZE_TOTAL=${GLANCE_LIMIT_IMAGE_SIZE_TOTAL:-2000} |
Julia Kreger | 5a64245 | 2021-07-19 07:01:29 -0700 | [diff] [blame] | 141 | |
Matthew Treinish | 1fa6536 | 2017-06-23 22:32:37 +0000 | [diff] [blame] | 142 | # If wsgi mode is uwsgi run glance under uwsgi, else default to eventlet |
| 143 | # TODO(mtreinish): Remove the eventlet path here and in all the similar |
| 144 | # conditionals below after the Pike release |
| 145 | if [[ "$WSGI_MODE" == "uwsgi" ]]; then |
| 146 | GLANCE_URL="$GLANCE_SERVICE_PROTOCOL://$GLANCE_SERVICE_HOST/image" |
| 147 | else |
| 148 | GLANCE_URL="$GLANCE_SERVICE_PROTOCOL://$GLANCE_HOSTPORT" |
| 149 | fi |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 150 | |
Dean Troyer | cc6b443 | 2013-04-08 15:38:03 -0500 | [diff] [blame] | 151 | # Functions |
| 152 | # --------- |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 153 | |
Dean Troyer | e4fa721 | 2014-01-15 15:04:49 -0600 | [diff] [blame] | 154 | # Test if any Glance services are enabled |
| 155 | # is_glance_enabled |
| 156 | function is_glance_enabled { |
Clark Boylan | 902158b | 2017-05-30 14:11:09 -0700 | [diff] [blame] | 157 | [[ ,${DISABLED_SERVICES} =~ ,"glance" ]] && return 1 |
Dean Troyer | e4fa721 | 2014-01-15 15:04:49 -0600 | [diff] [blame] | 158 | [[ ,${ENABLED_SERVICES} =~ ,"g-" ]] && return 0 |
| 159 | return 1 |
| 160 | } |
| 161 | |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 162 | # cleanup_glance() - Remove residual data files, anything left over from previous |
| 163 | # runs that a clean run would need to clean up |
Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 164 | function cleanup_glance { |
Dan Smith | 61b4fbf | 2021-03-09 08:05:37 -0800 | [diff] [blame] | 165 | # delete image files (glance) and all of the glance-remote temporary |
| 166 | # storage |
| 167 | sudo rm -rf $GLANCE_CACHE_DIR $GLANCE_IMAGE_DIR "${DATA_DIR}/glance-remote" |
Abhishek Kekane | 6f91da9 | 2019-10-17 09:02:41 +0000 | [diff] [blame] | 168 | |
| 169 | # Cleanup multiple stores directories |
| 170 | if [[ "$GLANCE_ENABLE_MULTIPLE_STORES" == "True" ]]; then |
| 171 | local store file_dir |
| 172 | for store in $(echo $GLANCE_MULTIPLE_FILE_STORES | tr "," "\n"); do |
| 173 | file_dir="${GLANCE_MULTISTORE_FILE_IMAGE_DIR}/${store}/" |
| 174 | sudo rm -rf $file_dir |
| 175 | done |
| 176 | |
| 177 | # Cleanup reserved stores directories |
| 178 | sudo rm -rf $GLANCE_STAGING_DIR $GLANCE_TASKS_DIR |
| 179 | fi |
Stephen Finucane | d5182ce | 2024-04-19 12:27:14 +0100 | [diff] [blame] | 180 | remove_uwsgi_config "$GLANCE_UWSGI_CONF" "glance-wsgi-api" |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 181 | } |
| 182 | |
Abhishek Kekane | b8cd9d1 | 2024-11-07 08:27:13 +0000 | [diff] [blame] | 183 | # Set multiple s3 store related config options |
| 184 | # |
| 185 | function configure_multiple_s3_stores { |
| 186 | enabled_backends="${GLANCE_S3_DEFAULT_BACKEND}:s3" |
| 187 | |
| 188 | iniset $GLANCE_API_CONF DEFAULT enabled_backends ${enabled_backends} |
| 189 | iniset $GLANCE_API_CONF glance_store default_backend $GLANCE_S3_DEFAULT_BACKEND |
| 190 | } |
| 191 | |
| 192 | # Set common S3 store options to given config section |
| 193 | # |
| 194 | # Arguments: |
| 195 | # config_section |
| 196 | # |
| 197 | function set_common_s3_store_params { |
| 198 | local config_section="$1" |
| 199 | openstack ec2 credential create |
| 200 | iniset $GLANCE_API_CONF $config_section s3_store_host "$SWIFT_SERVICE_PROTOCOL://$SERVICE_HOST:$S3_SERVICE_PORT" |
| 201 | iniset $GLANCE_API_CONF $config_section s3_store_access_key "$(openstack ec2 credential list -c Access -f value)" |
| 202 | iniset $GLANCE_API_CONF $config_section s3_store_secret_key "$(openstack ec2 credential list -c Secret -f value)" |
| 203 | iniset $GLANCE_API_CONF $config_section s3_store_create_bucket_on_put $GLANCE_S3_BUCKET_ON_PUT |
| 204 | iniset $GLANCE_API_CONF $config_section s3_store_bucket $GLANCE_S3_BUCKET_NAME |
| 205 | iniset $GLANCE_API_CONF $config_section s3_store_bucket_url_format "path" |
| 206 | if is_service_enabled tls-proxy; then |
| 207 | iniset $GLANCE_API_CONF $config_section s3_store_cacert $SSL_BUNDLE_FILE |
| 208 | fi |
| 209 | } |
| 210 | |
Abhishek Kekane | 057aaa6 | 2020-07-29 07:37:16 +0000 | [diff] [blame] | 211 | # Set multiple cinder store related config options for each of the cinder store |
| 212 | # |
| 213 | function configure_multiple_cinder_stores { |
| 214 | |
| 215 | local be be_name be_type enabled_backends |
| 216 | for be in ${CINDER_ENABLED_BACKENDS//,/ }; do |
| 217 | be_type=${be%%:*} |
| 218 | be_name=${be##*:} |
| 219 | enabled_backends+="${be_name}:cinder," |
| 220 | |
| 221 | set_common_cinder_store_params $be_name |
| 222 | iniset $GLANCE_API_CONF $be_name cinder_volume_type ${be_name} |
| 223 | if [[ "$be_type" == "nfs" ]]; then |
| 224 | mkdir -p "$GLANCE_NFS_MOUNTPOINT" |
| 225 | iniset $GLANCE_API_CONF $be_name cinder_mount_point_base "$GLANCE_NFS_MOUNTPOINT" |
| 226 | fi |
| 227 | done |
| 228 | iniset $GLANCE_API_CONF DEFAULT enabled_backends ${enabled_backends::-1} |
| 229 | iniset $GLANCE_API_CONF glance_store default_backend $GLANCE_CINDER_DEFAULT_BACKEND |
| 230 | } |
| 231 | |
| 232 | # Set common cinder store options to given config section |
| 233 | # |
| 234 | # Arguments: |
| 235 | # config_section |
| 236 | # |
| 237 | function set_common_cinder_store_params { |
| 238 | local config_section="$1" |
| 239 | iniset $GLANCE_API_CONF $config_section cinder_store_auth_address $KEYSTONE_SERVICE_URI_V3 |
| 240 | iniset $GLANCE_API_CONF $config_section cinder_store_user_name glance |
| 241 | iniset $GLANCE_API_CONF $config_section cinder_store_password $SERVICE_PASSWORD |
| 242 | iniset $GLANCE_API_CONF $config_section cinder_store_project_name $SERVICE_PROJECT_NAME |
| 243 | } |
| 244 | |
| 245 | # Configure multiple file stores options for each file store |
| 246 | # |
| 247 | # Arguments: |
| 248 | # |
| 249 | function configure_multiple_file_stores { |
| 250 | local store enabled_backends |
| 251 | enabled_backends="" |
| 252 | for store in $(echo $GLANCE_MULTIPLE_FILE_STORES | tr "," "\n"); do |
| 253 | enabled_backends+="${store}:file," |
| 254 | done |
| 255 | iniset $GLANCE_API_CONF DEFAULT enabled_backends ${enabled_backends::-1} |
| 256 | |
| 257 | # Glance multiple store Store specific configs |
| 258 | iniset $GLANCE_API_CONF glance_store default_backend $GLANCE_DEFAULT_BACKEND |
| 259 | local store |
| 260 | for store in $(echo $glance_multiple_file_stores | tr "," "\n"); do |
| 261 | iniset $GLANCE_API_CONF $store filesystem_store_datadir "${GLANCE_MULTISTORE_FILE_IMAGE_DIR}/${store}/" |
| 262 | done |
| 263 | } |
| 264 | |
| 265 | # Set reserved stores for glance |
| 266 | function configure_reserved_stores { |
| 267 | iniset $GLANCE_API_CONF os_glance_staging_store filesystem_store_datadir "${GLANCE_MULTISTORE_FILE_IMAGE_DIR}/os_glance_staging_store/" |
| 268 | iniset $GLANCE_API_CONF os_glance_tasks_store filesystem_store_datadir "${GLANCE_MULTISTORE_FILE_IMAGE_DIR}/os_glance_tasks_store/" |
| 269 | } |
| 270 | |
| 271 | # Copy rootwrap file from glance_store/etc/glance to /etc/glance |
| 272 | # |
| 273 | # Arguments: |
| 274 | # source_path Source path to copy rootwrap files from |
| 275 | # |
| 276 | function copy_rootwrap { |
| 277 | local source_path="$1" |
| 278 | # Make glance configuration directory if it is not exists |
| 279 | sudo install -d -o $STACK_USER $GLANCE_CONF_DIR |
| 280 | cp -r $source_path/rootwrap.* $GLANCE_CONF_DIR/ |
| 281 | } |
| 282 | |
| 283 | # Set glance_store related config options |
| 284 | # |
| 285 | # Arguments: |
| 286 | # USE_CINDER_FOR_GLANCE |
| 287 | # GLANCE_ENABLE_MULTIPLE_STORES |
| 288 | # |
| 289 | function configure_glance_store { |
| 290 | local use_cinder_for_glance="$1" |
| 291 | local glance_enable_multiple_stores="$2" |
| 292 | local be |
| 293 | |
| 294 | if [[ "$glance_enable_multiple_stores" == "False" ]]; then |
Abhishek Kekane | 057aaa6 | 2020-07-29 07:37:16 +0000 | [diff] [blame] | 295 | if [[ "$use_cinder_for_glance" == "True" ]]; then |
| 296 | # set common glance_store parameters |
| 297 | iniset $GLANCE_API_CONF glance_store stores "cinder,file,http" |
| 298 | iniset $GLANCE_API_CONF glance_store default_store cinder |
| 299 | |
| 300 | # set cinder related store parameters |
| 301 | set_common_cinder_store_params glance_store |
| 302 | # set nfs mount_point dir |
| 303 | for be in ${CINDER_ENABLED_BACKENDS//,/ }; do |
| 304 | local be_name=${be##*:} |
| 305 | if [[ "$be_name" == "nfs" ]]; then |
| 306 | mkdir -p $GLANCE_NFS_MOUNTPOINT |
| 307 | iniset $GLANCE_API_CONF glance_store cinder_mount_point_base $GLANCE_NFS_MOUNTPOINT |
| 308 | fi |
| 309 | done |
| 310 | fi |
| 311 | # Store specific configs |
| 312 | iniset $GLANCE_API_CONF glance_store filesystem_store_datadir $GLANCE_IMAGE_DIR/ |
| 313 | else |
| 314 | if [[ "$use_cinder_for_glance" == "True" ]]; then |
| 315 | # Configure multiple cinder stores for glance |
| 316 | configure_multiple_cinder_stores |
Abhishek Kekane | b8cd9d1 | 2024-11-07 08:27:13 +0000 | [diff] [blame] | 317 | elif ! is_service_enabled s-proxy && [[ "$GLANCE_USE_S3" == "False" ]]; then |
Abhishek Kekane | 057aaa6 | 2020-07-29 07:37:16 +0000 | [diff] [blame] | 318 | # Configure multiple file stores for glance |
| 319 | configure_multiple_file_stores |
| 320 | fi |
| 321 | # Configure reserved stores |
| 322 | configure_reserved_stores |
| 323 | fi |
| 324 | } |
| 325 | |
Dan Smith | 4e916ae | 2021-04-26 08:52:23 -0700 | [diff] [blame] | 326 | function configure_glance_quotas { |
| 327 | |
Lance Bragstad | afd0f84 | 2021-11-08 19:53:40 +0000 | [diff] [blame] | 328 | # Registered limit resources in keystone are system-specific resources. |
| 329 | # Make sure we use a system-scoped token to interact with this API. |
Dan Smith | 4e916ae | 2021-04-26 08:52:23 -0700 | [diff] [blame] | 330 | |
Lance Bragstad | afd0f84 | 2021-11-08 19:53:40 +0000 | [diff] [blame] | 331 | openstack --os-cloud devstack-system-admin registered limit create --service glance \ |
| 332 | --default-limit $GLANCE_LIMIT_IMAGE_SIZE_TOTAL --region $REGION_NAME image_size_total |
| 333 | openstack --os-cloud devstack-system-admin registered limit create --service glance \ |
| 334 | --default-limit $GLANCE_LIMIT_IMAGE_SIZE_TOTAL --region $REGION_NAME image_stage_total |
| 335 | openstack --os-cloud devstack-system-admin registered limit create --service glance \ |
| 336 | --default-limit 100 --region $REGION_NAME image_count_total |
| 337 | openstack --os-cloud devstack-system-admin registered limit create --service glance \ |
| 338 | --default-limit 100 --region $REGION_NAME image_count_uploading |
Dan Smith | 4e916ae | 2021-04-26 08:52:23 -0700 | [diff] [blame] | 339 | |
| 340 | # Tell glance to use these limits |
| 341 | iniset $GLANCE_API_CONF DEFAULT use_keystone_limits True |
| 342 | |
| 343 | # Configure oslo_limit so it can talk to keystone |
| 344 | iniset $GLANCE_API_CONF oslo_limit user_domain_name $SERVICE_DOMAIN_NAME |
| 345 | iniset $GLANCE_API_CONF oslo_limit password $SERVICE_PASSWORD |
| 346 | iniset $GLANCE_API_CONF oslo_limit username glance |
| 347 | iniset $GLANCE_API_CONF oslo_limit auth_type password |
| 348 | iniset $GLANCE_API_CONF oslo_limit auth_url $KEYSTONE_SERVICE_URI |
melanie witt | 2c96180 | 2022-03-03 23:54:49 +0000 | [diff] [blame] | 349 | iniset $GLANCE_API_CONF oslo_limit system_scope all |
Dan Smith | 4e916ae | 2021-04-26 08:52:23 -0700 | [diff] [blame] | 350 | iniset $GLANCE_API_CONF oslo_limit endpoint_id \ |
Grzegorz Grasza | ae40825 | 2021-10-26 10:37:07 +0200 | [diff] [blame] | 351 | $(openstack --os-cloud devstack-system-admin endpoint list --service glance -f value -c ID) |
Dan Smith | 4e916ae | 2021-04-26 08:52:23 -0700 | [diff] [blame] | 352 | |
| 353 | # Allow the glance service user to read quotas |
melanie witt | 2c96180 | 2022-03-03 23:54:49 +0000 | [diff] [blame] | 354 | openstack --os-cloud devstack-system-admin role add --user glance \ |
| 355 | --user-domain $SERVICE_DOMAIN_NAME --system all reader |
Dan Smith | 4e916ae | 2021-04-26 08:52:23 -0700 | [diff] [blame] | 356 | } |
| 357 | |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 358 | # configure_glance() - Set config files, create data dirs, etc |
Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 359 | function configure_glance { |
Dean Troyer | 8421c2b | 2015-03-16 13:52:19 -0500 | [diff] [blame] | 360 | sudo install -d -o $STACK_USER $GLANCE_CONF_DIR $GLANCE_METADEF_DIR |
Pawel Koniszewski | 76e3925 | 2014-09-06 07:06:46 -0400 | [diff] [blame] | 361 | |
Abhishek Kekane | 0ae5787 | 2020-02-17 06:11:15 +0000 | [diff] [blame] | 362 | # Set non-default configuration options for the API server |
Ian Wienand | ada886d | 2015-10-07 14:06:26 +1100 | [diff] [blame] | 363 | local dburl |
| 364 | dburl=`database_connection_url glance` |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 365 | |
Ben Nemec | 0399794 | 2013-08-10 09:56:16 -0500 | [diff] [blame] | 366 | iniset $GLANCE_API_CONF DEFAULT debug $ENABLE_DEBUG_LOG_LEVEL |
Jordan Pittier | ceca15d | 2015-06-19 11:46:36 +0200 | [diff] [blame] | 367 | iniset $GLANCE_API_CONF database connection $dburl |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 368 | iniset $GLANCE_API_CONF DEFAULT use_syslog $SYSLOG |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 369 | iniset $GLANCE_API_CONF DEFAULT image_cache_dir $GLANCE_CACHE_DIR/ |
Abhishek Kekane | 2211c77 | 2023-11-22 06:21:55 +0000 | [diff] [blame] | 370 | iniset $GLANCE_API_CONF DEFAULT image_cache_driver $GLANCE_CACHE_DRIVER |
ZhongShengping | 5fe60c1 | 2019-04-30 10:12:51 +0800 | [diff] [blame] | 371 | iniset $GLANCE_API_CONF oslo_concurrency lock_path $GLANCE_LOCK_DIR |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 372 | iniset $GLANCE_API_CONF paste_deploy flavor keystone+cachemanagement |
Dirk Mueller | 8ab64b3 | 2017-11-17 19:52:29 +0100 | [diff] [blame] | 373 | configure_keystone_authtoken_middleware $GLANCE_API_CONF glance |
Matt Riedemann | 45da777 | 2017-03-05 13:07:39 -0500 | [diff] [blame] | 374 | iniset $GLANCE_API_CONF oslo_messaging_notifications driver messagingv2 |
Brant Knudson | 2dd110c | 2015-03-14 12:39:14 -0500 | [diff] [blame] | 375 | iniset_rpc_backend glance $GLANCE_API_CONF |
Evgeny Antyshev | 1935458 | 2014-11-24 14:20:35 +0400 | [diff] [blame] | 376 | if [ "$VIRT_DRIVER" = 'libvirt' ] && [ "$LIBVIRT_TYPE" = 'parallels' ]; then |
| 377 | iniset $GLANCE_API_CONF DEFAULT disk_formats "ami,ari,aki,vhd,vmdk,raw,qcow2,vdi,iso,ploop" |
| 378 | fi |
Brian Rosmaita | 6e9f7c2 | 2020-10-13 14:20:38 -0400 | [diff] [blame] | 379 | # Only use these if you know what you are doing! See OSSN-0065 |
| 380 | iniset $GLANCE_API_CONF DEFAULT show_image_direct_url $GLANCE_SHOW_DIRECT_URL |
| 381 | iniset $GLANCE_API_CONF DEFAULT show_multiple_locations $GLANCE_SHOW_MULTIPLE_LOCATIONS |
Dan Smith | 803a7d4 | 2024-10-01 07:42:34 -0700 | [diff] [blame] | 382 | iniset $GLANCE_API_CONF image_format require_image_format_match $GLANCE_ENFORCE_IMAGE_FORMAT |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 383 | |
Abhishek Kekane | 057aaa6 | 2020-07-29 07:37:16 +0000 | [diff] [blame] | 384 | # Configure glance_store |
| 385 | configure_glance_store $USE_CINDER_FOR_GLANCE $GLANCE_ENABLE_MULTIPLE_STORES |
Flavio Percoco | fe65e2d | 2014-09-03 11:51:00 +0200 | [diff] [blame] | 386 | |
Timur Sufiev | a44dd9a | 2016-04-29 14:08:51 +0300 | [diff] [blame] | 387 | # CORS feature support - to allow calls from Horizon by default |
| 388 | if [ -n "$GLANCE_CORS_ALLOWED_ORIGIN" ]; then |
| 389 | iniset $GLANCE_API_CONF cors allowed_origin "$GLANCE_CORS_ALLOWED_ORIGIN" |
| 390 | else |
| 391 | iniset $GLANCE_API_CONF cors allowed_origin "http://$SERVICE_HOST" |
| 392 | fi |
| 393 | |
Abhishek Kekane | 6f91da9 | 2019-10-17 09:02:41 +0000 | [diff] [blame] | 394 | # No multiple stores for swift yet |
Abhishek Kekane | 057aaa6 | 2020-07-29 07:37:16 +0000 | [diff] [blame] | 395 | if [[ "$GLANCE_ENABLE_MULTIPLE_STORES" == "False" ]]; then |
Abhishek Kekane | b8cd9d1 | 2024-11-07 08:27:13 +0000 | [diff] [blame] | 396 | # Return if s3api is enabled for glance |
| 397 | if [[ "$GLANCE_USE_S3" == "True" ]]; then |
| 398 | if is_service_enabled s3api; then |
| 399 | # set common glance_store parameters |
| 400 | iniset $GLANCE_API_CONF glance_store stores "s3,file,http" |
| 401 | iniset $GLANCE_API_CONF glance_store default_store s3 |
| 402 | fi |
| 403 | elif is_service_enabled s-proxy; then |
| 404 | # Store the images in swift if enabled. |
Abhishek Kekane | 057aaa6 | 2020-07-29 07:37:16 +0000 | [diff] [blame] | 405 | iniset $GLANCE_API_CONF glance_store default_store swift |
| 406 | iniset $GLANCE_API_CONF glance_store swift_store_create_container_on_put True |
Jamie Lennox | f4f01c6 | 2015-06-19 02:52:41 +0000 | [diff] [blame] | 407 | |
Abhishek Kekane | 057aaa6 | 2020-07-29 07:37:16 +0000 | [diff] [blame] | 408 | iniset $GLANCE_API_CONF glance_store swift_store_config_file $GLANCE_SWIFT_STORE_CONF |
| 409 | iniset $GLANCE_API_CONF glance_store default_swift_reference ref1 |
| 410 | iniset $GLANCE_API_CONF glance_store stores "file, http, swift" |
| 411 | if is_service_enabled tls-proxy; then |
| 412 | iniset $GLANCE_API_CONF glance_store swift_store_cacert $SSL_BUNDLE_FILE |
| 413 | fi |
| 414 | iniset $GLANCE_API_CONF DEFAULT graceful_shutdown_timeout "$SERVICE_GRACEFUL_SHUTDOWN_TIMEOUT" |
| 415 | |
| 416 | iniset $GLANCE_SWIFT_STORE_CONF ref1 user $SERVICE_PROJECT_NAME:glance-swift |
| 417 | |
| 418 | iniset $GLANCE_SWIFT_STORE_CONF ref1 key $SERVICE_PASSWORD |
| 419 | iniset $GLANCE_SWIFT_STORE_CONF ref1 auth_address $KEYSTONE_SERVICE_URI/v3 |
| 420 | iniset $GLANCE_SWIFT_STORE_CONF ref1 auth_version 3 |
Vladislav Kuzmin | 9cbd02d | 2020-05-20 12:14:04 +0400 | [diff] [blame] | 421 | fi |
Abhishek Kekane | b8cd9d1 | 2024-11-07 08:27:13 +0000 | [diff] [blame] | 422 | else |
| 423 | if [[ "$GLANCE_USE_S3" == "True" ]]; then |
| 424 | if is_service_enabled s3api; then |
| 425 | configure_multiple_s3_stores |
| 426 | fi |
| 427 | fi |
Dean Troyer | c77b932 | 2013-03-29 10:51:01 -0500 | [diff] [blame] | 428 | fi |
| 429 | |
Matthew Treinish | 1fa6536 | 2017-06-23 22:32:37 +0000 | [diff] [blame] | 430 | # We need to tell glance what it's public endpoint is so that the version |
| 431 | # discovery document will be correct |
| 432 | iniset $GLANCE_API_CONF DEFAULT public_endpoint $GLANCE_URL |
| 433 | |
Rob Crittenden | 18d4778 | 2014-03-19 17:47:42 -0400 | [diff] [blame] | 434 | if is_service_enabled tls-proxy; then |
| 435 | iniset $GLANCE_API_CONF DEFAULT bind_port $GLANCE_SERVICE_PORT_INT |
Jens Harbott | 32c0089 | 2019-04-10 10:33:39 +0000 | [diff] [blame] | 436 | iniset $GLANCE_API_CONF keystone_authtoken identity_uri $KEYSTONE_SERVICE_URI |
Rob Crittenden | 18d4778 | 2014-03-19 17:47:42 -0400 | [diff] [blame] | 437 | fi |
| 438 | |
Louis Taylor | 701276a | 2015-02-11 19:34:09 +0000 | [diff] [blame] | 439 | # Format logging |
Sean Dague | 9751be6 | 2016-04-05 12:08:57 -0400 | [diff] [blame] | 440 | setup_logging $GLANCE_API_CONF |
Louis Taylor | 701276a | 2015-02-11 19:34:09 +0000 | [diff] [blame] | 441 | |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 442 | cp -p $GLANCE_DIR/etc/glance-api-paste.ini $GLANCE_API_PASTE_INI |
| 443 | |
Brian Rosmaita | 44a19b4 | 2017-12-11 18:07:50 -0500 | [diff] [blame] | 444 | # Set non-default configuration options for the glance-cache |
Ben Nemec | 0399794 | 2013-08-10 09:56:16 -0500 | [diff] [blame] | 445 | iniset $GLANCE_CACHE_CONF DEFAULT debug $ENABLE_DEBUG_LOG_LEVEL |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 446 | iniset $GLANCE_CACHE_CONF DEFAULT use_syslog $SYSLOG |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 447 | iniset $GLANCE_CACHE_CONF DEFAULT image_cache_dir $GLANCE_CACHE_DIR/ |
Abhishek Kekane | 2211c77 | 2023-11-22 06:21:55 +0000 | [diff] [blame] | 448 | iniset $GLANCE_CACHE_CONF DEFAULT image_cache_driver $GLANCE_CACHE_DRIVER |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 449 | |
Flavio Percoco | fe65e2d | 2014-09-03 11:51:00 +0200 | [diff] [blame] | 450 | # Store specific confs |
Flavio Percoco | fe65e2d | 2014-09-03 11:51:00 +0200 | [diff] [blame] | 451 | iniset $GLANCE_CACHE_CONF glance_store filesystem_store_datadir $GLANCE_IMAGE_DIR/ |
| 452 | |
bhagyashris | 6a25fb9 | 2017-12-14 13:23:41 +0530 | [diff] [blame] | 453 | # Set default configuration options for the glance-image-import |
| 454 | iniset $GLANCE_IMAGE_IMPORT_CONF image_import_opts image_import_plugins [] |
| 455 | iniset $GLANCE_IMAGE_IMPORT_CONF inject_metadata_properties ignore_user_roles admin |
| 456 | iniset $GLANCE_IMAGE_IMPORT_CONF inject_metadata_properties inject |
| 457 | |
Dirk Mueller | 46d1ba6 | 2013-09-09 14:31:37 +0200 | [diff] [blame] | 458 | cp -p $GLANCE_DIR/etc/schema-image.json $GLANCE_SCHEMA_JSON |
Pawel Koniszewski | 76e3925 | 2014-09-06 07:06:46 -0400 | [diff] [blame] | 459 | |
| 460 | cp -p $GLANCE_DIR/etc/metadefs/*.json $GLANCE_METADEF_DIR |
Rob Crittenden | 18d4778 | 2014-03-19 17:47:42 -0400 | [diff] [blame] | 461 | |
Sean Dague | f3b2f4c | 2017-04-13 10:11:48 -0400 | [diff] [blame] | 462 | if is_service_enabled tls-proxy; then |
Rob Crittenden | 18d4778 | 2014-03-19 17:47:42 -0400 | [diff] [blame] | 463 | CINDER_SERVICE_HOST=${CINDER_SERVICE_HOST:-$SERVICE_HOST} |
| 464 | CINDER_SERVICE_PORT=${CINDER_SERVICE_PORT:-8776} |
| 465 | |
Brian Rosmaita | b43810a | 2019-02-07 16:46:49 -0500 | [diff] [blame] | 466 | iniset $GLANCE_API_CONF DEFAULT cinder_endpoint_template "https://$CINDER_SERVICE_HOST:$CINDER_SERVICE_PORT/v3/%(project_id)s" |
| 467 | iniset $GLANCE_CACHE_CONF DEFAULT cinder_endpoint_template "https://$CINDER_SERVICE_HOST:$CINDER_SERVICE_PORT/v3/%(project_id)s" |
Rob Crittenden | 18d4778 | 2014-03-19 17:47:42 -0400 | [diff] [blame] | 468 | fi |
Matthew Treinish | 1fa6536 | 2017-06-23 22:32:37 +0000 | [diff] [blame] | 469 | |
Dan Smith | 09eea0b | 2020-07-09 08:31:51 -0700 | [diff] [blame] | 470 | if [[ "$GLANCE_STANDALONE" == False ]]; then |
Stephen Finucane | 497b4fd | 2024-10-18 13:47:55 +0100 | [diff] [blame] | 471 | write_local_uwsgi_http_config "$GLANCE_UWSGI_CONF" "$GLANCE_UWSGI" "/image" "glance-api" |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 472 | # Grab our uwsgi listen address and use that to fill out our |
| 473 | # worker_self_reference_url config |
| 474 | iniset $GLANCE_API_CONF DEFAULT worker_self_reference_url \ |
Stephen Finucane | 497b4fd | 2024-10-18 13:47:55 +0100 | [diff] [blame] | 475 | $(awk '-F= ' '/^http-socket/ { print "http://"$2}' $GLANCE_UWSGI_CONF) |
Matthew Treinish | 1fa6536 | 2017-06-23 22:32:37 +0000 | [diff] [blame] | 476 | else |
Dan Smith | 09eea0b | 2020-07-09 08:31:51 -0700 | [diff] [blame] | 477 | write_local_proxy_http_config glance "http://$GLANCE_SERVICE_HOST:$GLANCE_SERVICE_PORT_INT" "/image" |
Matthew Treinish | 1fa6536 | 2017-06-23 22:32:37 +0000 | [diff] [blame] | 478 | iniset $GLANCE_API_CONF DEFAULT bind_host $GLANCE_SERVICE_LISTEN_ADDRESS |
Dan Smith | fcbf3e9 | 2020-07-17 10:14:14 -0700 | [diff] [blame] | 479 | iniset $GLANCE_API_CONF DEFAULT bind_port $GLANCE_SERVICE_PORT_INT |
Matthew Treinish | 1fa6536 | 2017-06-23 22:32:37 +0000 | [diff] [blame] | 480 | iniset $GLANCE_API_CONF DEFAULT workers "$API_WORKERS" |
Abhishek Kekane | d251d12 | 2024-01-29 18:20:06 +0000 | [diff] [blame] | 481 | iniset $GLANCE_API_CONF DEFAULT worker_self_reference_url $GLANCE_URL |
Matthew Treinish | 1fa6536 | 2017-06-23 22:32:37 +0000 | [diff] [blame] | 482 | fi |
Ghanshyam Mann | 8c93049 | 2021-03-05 09:40:39 -0600 | [diff] [blame] | 483 | |
Grzegorz Grasza | 8615563 | 2021-10-18 16:52:06 +0200 | [diff] [blame] | 484 | if [[ "$GLANCE_ENFORCE_SCOPE" == True || "$ENFORCE_SCOPE" == True ]] ; then |
Ghanshyam Mann | 8c93049 | 2021-03-05 09:40:39 -0600 | [diff] [blame] | 485 | iniset $GLANCE_API_CONF oslo_policy enforce_scope true |
| 486 | iniset $GLANCE_API_CONF oslo_policy enforce_new_defaults true |
| 487 | iniset $GLANCE_API_CONF DEFAULT enforce_secure_rbac true |
Ghanshyam Mann | 69d71cf | 2023-01-10 20:13:47 -0600 | [diff] [blame] | 488 | else |
| 489 | iniset $GLANCE_API_CONF oslo_policy enforce_scope false |
| 490 | iniset $GLANCE_API_CONF oslo_policy enforce_new_defaults false |
| 491 | iniset $GLANCE_API_CONF DEFAULT enforce_secure_rbac false |
Ghanshyam Mann | 8c93049 | 2021-03-05 09:40:39 -0600 | [diff] [blame] | 492 | fi |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 493 | } |
| 494 | |
Dean Troyer | 42a59c2 | 2014-03-03 14:31:29 -0600 | [diff] [blame] | 495 | # create_glance_accounts() - Set up common required glance accounts |
| 496 | |
Wayne Okuma | dd62293 | 2015-03-31 00:28:39 -0700 | [diff] [blame] | 497 | # Project User Roles |
| 498 | # --------------------------------------------------------------------- |
Sean Dague | 7580a0c | 2016-02-17 06:23:36 -0500 | [diff] [blame] | 499 | # SERVICE_PROJECT_NAME glance service |
| 500 | # SERVICE_PROJECT_NAME glance-swift ResellerAdmin (if Swift is enabled) |
| 501 | # SERVICE_PROJECT_NAME glance-search search (if Search is enabled) |
Dean Troyer | 42a59c2 | 2014-03-03 14:31:29 -0600 | [diff] [blame] | 502 | |
| 503 | function create_glance_accounts { |
| 504 | if is_service_enabled g-api; then |
Bartosz Górski | 0abde39 | 2014-02-28 14:15:19 +0100 | [diff] [blame] | 505 | |
Jamie Lennox | 85ff532 | 2015-01-28 14:28:01 +1000 | [diff] [blame] | 506 | create_service_user "glance" |
Bartosz Górski | 0abde39 | 2014-02-28 14:15:19 +0100 | [diff] [blame] | 507 | |
Dean Troyer | 42a59c2 | 2014-03-03 14:31:29 -0600 | [diff] [blame] | 508 | # required for swift access |
| 509 | if is_service_enabled s-proxy; then |
Jamie Lennox | cbcbd8f | 2016-01-21 16:08:14 -0600 | [diff] [blame] | 510 | create_service_user "glance-swift" "ResellerAdmin" |
Dean Troyer | 42a59c2 | 2014-03-03 14:31:29 -0600 | [diff] [blame] | 511 | fi |
Bartosz Górski | 0abde39 | 2014-02-28 14:15:19 +0100 | [diff] [blame] | 512 | |
Sean Dague | 985e958 | 2016-02-10 07:25:24 -0500 | [diff] [blame] | 513 | get_or_create_service "glance" "image" "Glance Image Service" |
Matt Riedemann | ae4578b | 2016-04-23 01:45:40 +0000 | [diff] [blame] | 514 | get_or_create_endpoint \ |
Sean Dague | 985e958 | 2016-02-10 07:25:24 -0500 | [diff] [blame] | 515 | "image" \ |
| 516 | "$REGION_NAME" \ |
Matthew Treinish | 1fa6536 | 2017-06-23 22:32:37 +0000 | [diff] [blame] | 517 | "$GLANCE_URL" |
Jens Rosenboom | 890342e | 2016-09-13 22:41:41 +0200 | [diff] [blame] | 518 | |
| 519 | # Note(frickler): Crude workaround for https://bugs.launchpad.net/glance-store/+bug/1620999 |
| 520 | service_domain_id=$(get_or_create_domain $SERVICE_DOMAIN_NAME) |
| 521 | iniset $GLANCE_SWIFT_STORE_CONF ref1 project_domain_id $service_domain_id |
| 522 | iniset $GLANCE_SWIFT_STORE_CONF ref1 user_domain_id $service_domain_id |
Dan Smith | 4e916ae | 2021-04-26 08:52:23 -0700 | [diff] [blame] | 523 | |
| 524 | if [[ "$GLANCE_ENABLE_QUOTAS" = True ]]; then |
| 525 | configure_glance_quotas |
| 526 | fi |
| 527 | |
Abhishek Kekane | b8cd9d1 | 2024-11-07 08:27:13 +0000 | [diff] [blame] | 528 | if is_service_enabled s3api && [[ "$GLANCE_USE_S3" == "True" ]]; then |
| 529 | if [[ "$GLANCE_ENABLE_MULTIPLE_STORES" == "False" ]]; then |
| 530 | set_common_s3_store_params glance_store |
| 531 | else |
| 532 | set_common_s3_store_params $GLANCE_S3_DEFAULT_BACKEND |
| 533 | fi |
| 534 | fi |
Dean Troyer | 42a59c2 | 2014-03-03 14:31:29 -0600 | [diff] [blame] | 535 | fi |
| 536 | } |
| 537 | |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 538 | # init_glance() - Initialize databases, etc. |
Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 539 | function init_glance { |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 540 | # Delete existing images |
| 541 | rm -rf $GLANCE_IMAGE_DIR |
| 542 | mkdir -p $GLANCE_IMAGE_DIR |
| 543 | |
Radosław Piliszek | 09e860f | 2020-01-19 12:41:14 +0100 | [diff] [blame] | 544 | # (Re)create glance database |
| 545 | recreate_database glance |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 546 | |
Radosław Piliszek | 09e860f | 2020-01-19 12:41:14 +0100 | [diff] [blame] | 547 | time_start "dbsync" |
| 548 | # Migrate glance database |
| 549 | $GLANCE_BIN_DIR/glance-manage --config-file $GLANCE_CONF_DIR/glance-api.conf db_sync |
Dean Troyer | bc071bc | 2012-10-01 14:06:44 -0500 | [diff] [blame] | 550 | |
Radosław Piliszek | 09e860f | 2020-01-19 12:41:14 +0100 | [diff] [blame] | 551 | # Load metadata definitions |
| 552 | $GLANCE_BIN_DIR/glance-manage --config-file $GLANCE_CONF_DIR/glance-api.conf db_load_metadefs |
| 553 | time_stop "dbsync" |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 554 | } |
| 555 | |
| 556 | # install_glanceclient() - Collect source and prepare |
Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 557 | function install_glanceclient { |
Sean Dague | e08ab10 | 2014-11-13 17:09:28 -0500 | [diff] [blame] | 558 | if use_library_from_git "python-glanceclient"; then |
| 559 | git_clone_by_name "python-glanceclient" |
| 560 | setup_dev_lib "python-glanceclient" |
Louis Taylor | 8df690c | 2014-11-20 13:09:03 +0000 | [diff] [blame] | 561 | sudo install -D -m 0644 -o $STACK_USER {${GITDIR["python-glanceclient"]}/tools/,/etc/bash_completion.d/}glance.bash_completion |
Sean Dague | 5cb1906 | 2014-11-01 01:37:45 +0100 | [diff] [blame] | 562 | fi |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 563 | } |
| 564 | |
| 565 | # install_glance() - Collect source and prepare |
Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 566 | function install_glance { |
Radosław Piliszek | be26306 | 2020-03-30 09:56:53 +0200 | [diff] [blame] | 567 | local glance_store_extras=() |
| 568 | |
| 569 | if is_service_enabled cinder; then |
| 570 | glance_store_extras=("cinder" "${glance_store_extras[@]}") |
| 571 | fi |
| 572 | |
| 573 | if is_service_enabled swift; then |
| 574 | glance_store_extras=("swift" "${glance_store_extras[@]}") |
| 575 | fi |
| 576 | |
Flavio Percoco | 4f78f8f | 2014-09-09 09:37:42 +0200 | [diff] [blame] | 577 | # Install glance_store from git so we make sure we're testing |
| 578 | # the latest code. |
Sean Dague | ee5ae7b | 2014-11-13 13:23:27 -0500 | [diff] [blame] | 579 | if use_library_from_git "glance_store"; then |
| 580 | git_clone_by_name "glance_store" |
Radosław Piliszek | be26306 | 2020-03-30 09:56:53 +0200 | [diff] [blame] | 581 | setup_dev_lib "glance_store" $(join_extras "${glance_store_extras[@]}") |
Abhishek Kekane | 057aaa6 | 2020-07-29 07:37:16 +0000 | [diff] [blame] | 582 | copy_rootwrap ${DEST}/glance_store/etc/glance |
Radosław Piliszek | be26306 | 2020-03-30 09:56:53 +0200 | [diff] [blame] | 583 | else |
| 584 | # we still need to pass extras |
| 585 | pip_install_gr_extras glance-store $(join_extras "${glance_store_extras[@]}") |
Abhishek Kekane | 057aaa6 | 2020-07-29 07:37:16 +0000 | [diff] [blame] | 586 | copy_rootwrap $GLANCE_STORE_ROOTWRAP_BASE_DIR |
Sean Dague | ee5ae7b | 2014-11-13 13:23:27 -0500 | [diff] [blame] | 587 | fi |
Flavio Percoco | 4f78f8f | 2014-09-09 09:37:42 +0200 | [diff] [blame] | 588 | |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 589 | git_clone $GLANCE_REPO $GLANCE_DIR $GLANCE_BRANCH |
Wayne Okuma | dd62293 | 2015-03-31 00:28:39 -0700 | [diff] [blame] | 590 | |
Wayne Okuma | dd62293 | 2015-03-31 00:28:39 -0700 | [diff] [blame] | 591 | setup_develop $GLANCE_DIR |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 592 | } |
| 593 | |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 594 | # glance_remote_conf() - Return the path to an alternate config file for |
| 595 | # the remote glance clone |
| 596 | function glance_remote_conf { |
Dan Smith | 61b4fbf | 2021-03-09 08:05:37 -0800 | [diff] [blame] | 597 | echo $(dirname "${GLANCE_CONF_DIR}")/glance-remote/$(basename "$1") |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 598 | } |
| 599 | |
| 600 | # start_glance_remote_clone() - Clone the regular glance api worker |
| 601 | function start_glance_remote_clone { |
Dan Smith | 61b4fbf | 2021-03-09 08:05:37 -0800 | [diff] [blame] | 602 | local glance_remote_conf_dir glance_remote_port remote_data |
Dan Smith | 25cd7eb | 2023-09-21 07:12:15 -0700 | [diff] [blame] | 603 | local glance_remote_uwsgi venv |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 604 | |
Dan Smith | 61b4fbf | 2021-03-09 08:05:37 -0800 | [diff] [blame] | 605 | glance_remote_conf_dir="$(glance_remote_conf "")" |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 606 | glance_remote_port=$(get_random_port) |
Dan Smith | 61b4fbf | 2021-03-09 08:05:37 -0800 | [diff] [blame] | 607 | glance_remote_uwsgi="$(glance_remote_conf $GLANCE_UWSGI_CONF)" |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 608 | |
| 609 | # Clone the existing ready-to-go glance-api setup |
Dan Smith | 61b4fbf | 2021-03-09 08:05:37 -0800 | [diff] [blame] | 610 | sudo rm -Rf "$glance_remote_conf_dir" |
| 611 | sudo cp -r "$GLANCE_CONF_DIR" "$glance_remote_conf_dir" |
| 612 | sudo chown $STACK_USER -R "$glance_remote_conf_dir" |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 613 | |
| 614 | # Point this worker at different data dirs |
| 615 | remote_data="${DATA_DIR}/glance-remote" |
| 616 | mkdir -p $remote_data/os_glance_tasks_store \ |
Dan Smith | 61b4fbf | 2021-03-09 08:05:37 -0800 | [diff] [blame] | 617 | "${remote_data}/os_glance_staging_store" |
| 618 | iniset $(glance_remote_conf "$GLANCE_API_CONF") os_glance_staging_store \ |
| 619 | filesystem_store_datadir "${remote_data}/os_glance_staging_store" |
| 620 | iniset $(glance_remote_conf "$GLANCE_API_CONF") os_glance_tasks_store \ |
| 621 | filesystem_store_datadir "${remote_data}/os_glance_tasks_store" |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 622 | |
Abhishek Kekane | 00ac547 | 2021-08-09 05:54:32 +0000 | [diff] [blame] | 623 | # Point this worker to use different cache dir |
| 624 | mkdir -p "$remote_data/cache" |
| 625 | iniset $(glance_remote_conf "$GLANCE_API_CONF") DEFAULT \ |
| 626 | image_cache_dir "${remote_data}/cache" |
| 627 | |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 628 | # Change our uwsgi to our new port |
| 629 | sed -ri "s/^(http-socket.*):[0-9]+/\1:$glance_remote_port/" \ |
Dan Smith | 61b4fbf | 2021-03-09 08:05:37 -0800 | [diff] [blame] | 630 | "$glance_remote_uwsgi" |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 631 | |
| 632 | # Update the self-reference url with our new port |
| 633 | iniset $(glance_remote_conf $GLANCE_API_CONF) DEFAULT \ |
| 634 | worker_self_reference_url \ |
| 635 | $(awk '-F= ' '/^http-socket/ { print "http://"$2 }' \ |
Dan Smith | 61b4fbf | 2021-03-09 08:05:37 -0800 | [diff] [blame] | 636 | "$glance_remote_uwsgi") |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 637 | |
| 638 | # We need to create the systemd service for the clone, but then |
| 639 | # change it to include an Environment line to point the WSGI app |
| 640 | # at the alternate config directory. |
Dan Smith | 25cd7eb | 2023-09-21 07:12:15 -0700 | [diff] [blame] | 641 | if [[ "$GLOBAL_VENV" == True ]]; then |
| 642 | venv="--venv $DEVSTACK_VENV" |
| 643 | fi |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 644 | write_uwsgi_user_unit_file devstack@g-api-r.service "$(which uwsgi) \ |
| 645 | --procname-prefix \ |
| 646 | glance-api-remote \ |
Dan Smith | 5a51aa5 | 2023-08-23 10:43:32 -0700 | [diff] [blame] | 647 | --ini $glance_remote_uwsgi \ |
Dan Smith | 25cd7eb | 2023-09-21 07:12:15 -0700 | [diff] [blame] | 648 | $venv" \ |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 649 | "" "$STACK_USER" |
Dan Smith | 5a51aa5 | 2023-08-23 10:43:32 -0700 | [diff] [blame] | 650 | iniadd -sudo ${SYSTEMD_DIR}/devstack@g-api-r.service \ |
Dan Smith | 61b4fbf | 2021-03-09 08:05:37 -0800 | [diff] [blame] | 651 | "Service" "Environment" \ |
| 652 | "OS_GLANCE_CONFIG_DIR=$glance_remote_conf_dir" |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 653 | |
| 654 | # Reload and restart with the new config |
| 655 | $SYSTEMCTL daemon-reload |
| 656 | $SYSTEMCTL restart devstack@g-api-r |
| 657 | |
| 658 | get_or_create_service glance_remote image_remote "Alternate glance" |
| 659 | get_or_create_endpoint image_remote $REGION_NAME \ |
| 660 | $(awk '-F= ' '/^http-socket/ { print "http://"$2 }' \ |
Dan Smith | 61b4fbf | 2021-03-09 08:05:37 -0800 | [diff] [blame] | 661 | $glance_remote_uwsgi) |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 662 | } |
| 663 | |
Sean Dague | 0eebeb4 | 2017-08-30 14:16:58 -0400 | [diff] [blame] | 664 | # start_glance() - Start running processes |
Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 665 | function start_glance { |
Rob Crittenden | 18d4778 | 2014-03-19 17:47:42 -0400 | [diff] [blame] | 666 | local service_protocol=$GLANCE_SERVICE_PROTOCOL |
| 667 | if is_service_enabled tls-proxy; then |
Matthew Treinish | 1fa6536 | 2017-06-23 22:32:37 +0000 | [diff] [blame] | 668 | if [[ "$WSGI_MODE" != "uwsgi" ]]; then |
| 669 | start_tls_proxy glance-service '*' $GLANCE_SERVICE_PORT $GLANCE_SERVICE_HOST $GLANCE_SERVICE_PORT_INT |
| 670 | fi |
Rob Crittenden | 18d4778 | 2014-03-19 17:47:42 -0400 | [diff] [blame] | 671 | fi |
| 672 | |
Dan Smith | 09eea0b | 2020-07-09 08:31:51 -0700 | [diff] [blame] | 673 | if [[ "$GLANCE_STANDALONE" == False ]]; then |
Ian Wienand | 312517d | 2018-06-22 22:23:29 +1000 | [diff] [blame] | 674 | run_process g-api "$(which uwsgi) --procname-prefix glance-api --ini $GLANCE_UWSGI_CONF" |
Matthew Treinish | 1fa6536 | 2017-06-23 22:32:37 +0000 | [diff] [blame] | 675 | else |
Brian Rosmaita | 96269d8 | 2018-12-17 10:38:42 -0500 | [diff] [blame] | 676 | run_process g-api "$GLANCE_BIN_DIR/glance-api --config-dir=$GLANCE_CONF_DIR" |
Matthew Treinish | 1fa6536 | 2017-06-23 22:32:37 +0000 | [diff] [blame] | 677 | fi |
Rob Crittenden | 18d4778 | 2014-03-19 17:47:42 -0400 | [diff] [blame] | 678 | |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 679 | if is_service_enabled g-api-r; then |
| 680 | echo "Starting the g-api-r clone service..." |
| 681 | start_glance_remote_clone |
| 682 | fi |
| 683 | |
Matthew Treinish | 1fa6536 | 2017-06-23 22:32:37 +0000 | [diff] [blame] | 684 | echo "Waiting for g-api ($GLANCE_SERVICE_HOST) to start..." |
| 685 | if ! wait_for_service $SERVICE_TIMEOUT $GLANCE_URL; then |
Sean Dague | 101b424 | 2013-10-22 08:47:11 -0400 | [diff] [blame] | 686 | die $LINENO "g-api did not start" |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 687 | fi |
| 688 | } |
| 689 | |
Dean Troyer | 699a29f | 2012-09-10 14:10:27 -0500 | [diff] [blame] | 690 | # stop_glance() - Stop running processes |
Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 691 | function stop_glance { |
Chris Dent | 2f27a0e | 2014-09-09 13:46:02 +0100 | [diff] [blame] | 692 | stop_process g-api |
Dan Smith | 802259a | 2021-01-12 22:55:57 +0000 | [diff] [blame] | 693 | stop_process g-api-r |
Dean Troyer | 73f6f25 | 2012-09-17 11:22:21 -0500 | [diff] [blame] | 694 | } |
| 695 | |
| 696 | # Restore xtrace |
Ian Wienand | 523f488 | 2015-10-13 11:03:03 +1100 | [diff] [blame] | 697 | $_XTRACE_GLANCE |
Sean Dague | 584d90e | 2013-03-29 14:34:53 -0400 | [diff] [blame] | 698 | |
Adam Spiers | 6a5aa7c | 2013-10-24 11:27:02 +0100 | [diff] [blame] | 699 | # Tell emacs to use shell-script-mode |
| 700 | ## Local variables: |
| 701 | ## mode: shell-script |
| 702 | ## End: |