charm-glance/templates/stein/glance-api.conf
Trent Lloyd e553d095d6 Remove rbd_store_chunk_size=8 reverting to default
We have shipped rbd_store_chunk_size=8 in our glance configuration for a
very long time, this value was sometimes suggested in older upstream
documentation and has the effect of halving the number of rados objects
used to store glance images.

When using qcow2 images in ceph the created VM volume will have an
rbd_store_chunk_size=4 (the default) however in modern clouds when
images are in the raw format we will use copy-on-write cloning from the
image to the volume, which means all such VM volumes inherit
rbd_store_chunk_size=8 from the parent. This has negative performance
implications for working volumes as there are object-wide locks that now
cover twice as much data and a wider chunk of sequential disk storage
will hit the same OSD.

Any overhead benefit of using objects only double the size (and thus
half in number) is very likely long relegated to history given the
number of volumes we're likely to have in a cloud versus base images, so
there doesn't seem to be any benefit to this setting and outside of a
few glance documents this rbd option is not documented anywhere I can
find as a suggestion or with any evidence of an advantage of performance
improvement from storing images this way.

Remove rbd_store_chunk_size=8 from all configuration files so that it
reverts to the default of 4.

Existing images (and old or new dependent volumes of them) will maintain
the existing rbd_store_chunk_size=8 and continue to work correctly. New
images will be created with the new rbd_store_chunk_size=4.

Change-Id: I5f6801c418430bbdcda53b94fcd51ed2fc230b68
2020-07-07 14:22:01 +08:00

99 lines
2.1 KiB
Plaintext

[DEFAULT]
verbose = {{ verbose }}
use_syslog = {{ use_syslog }}
debug = {{ debug }}
workers = {{ workers }}
bind_host = {{ bind_host }}
{% if ext -%}
bind_port = {{ ext }}
{% elif bind_port -%}
bind_port = {{ bind_port }}
{% else -%}
bind_port = 9292
{% endif -%}
{% if transport_url %}
transport_url = {{ transport_url }}
{% endif %}
log_file = /var/log/glance/api.log
backlog = 4096
{% if expose_image_locations -%}
show_multiple_locations = {{ expose_image_locations }}
show_image_direct_url = {{ expose_image_locations }}
{% endif -%}
{% if api_config_flags -%}
{% for key, value in api_config_flags.items() -%}
{{ key }} = {{ value }}
{% endfor -%}
{% endif -%}
delayed_delete = False
scrub_time = 43200
scrubber_datadir = /var/lib/glance/scrubber
image_cache_dir = /var/lib/glance/image-cache/
db_enforce_mysql_charset = False
{% if image_size_cap -%}
image_size_cap = {{ image_size_cap }}
{% endif -%}
[glance_store]
{%- if use_internal_endpoints %}
catalog_info = {{ volume_catalog_info }}
{%- endif %}
filesystem_store_datadir = {{ filesystem_store_datadir }}
stores = {{ known_stores }}
{% if rbd_pool -%}
default_store = rbd
{% elif swift_store -%}
default_store = swift
{% elif cinder_store -%}
default_store = cinder
{% else -%}
default_store = file
{% endif -%}
{% if swift_store -%}
default_swift_reference = swift
swift_store_config_file = /etc/glance/glance-swift.conf
swift_store_create_container_on_put = true
{% endif -%}
{% if rbd_pool -%}
rbd_store_ceph_conf = /etc/ceph/ceph.conf
rbd_store_user = {{ rbd_user }}
rbd_store_pool = {{ rbd_pool }}
{% endif -%}
[image_format]
disk_formats = {{ disk_formats }}
{% if container_formats -%}
container_formats = {{ container_formats }}
{% endif -%}
{% include "section-keystone-authtoken-v3only" %}
{% if auth_host -%}
[paste_deploy]
flavor = keystone
{% endif %}
[barbican]
auth_endpoint = {{ service_protocol }}://{{ service_host }}:{{ service_port }}/v3
{% include "parts/section-database" %}
{% include "section-oslo-messaging-rabbit" %}
{% include "section-oslo-notifications" %}
{% include "section-oslo-middleware" %}
{% include "parts/section-storage" %}