mirror of https://github.com/ceph/ceph-ansible.git
139 lines
5.8 KiB
Django/Jinja
139 lines
5.8 KiB
Django/Jinja
#jinja2: trim_blocks: "true", lstrip_blocks: "true"
|
|
# {{ ansible_managed }}
|
|
|
|
[global]
|
|
{% if not cephx %}
|
|
auth cluster required = none
|
|
auth service required = none
|
|
auth client required = none
|
|
auth supported = none
|
|
{% endif %}
|
|
{% if ip_version == 'ipv6' %}
|
|
ms bind ipv6 = true
|
|
{% endif %}
|
|
{% if common_single_host_mode is defined and common_single_host_mode %}
|
|
osd crush chooseleaf type = 0
|
|
{% endif %}
|
|
{# NOTE (leseb): the blank lines in-between are needed otherwise we won't get any line break #}
|
|
|
|
{% set nb_mon = groups.get(mon_group_name, []) | length | int %}
|
|
{% set nb_client = groups.get(client_group_name, []) | length | int %}
|
|
{% set nb_osd = groups.get(osd_group_name, []) | length | int %}
|
|
{% if inventory_hostname in groups.get(client_group_name, []) and not inventory_hostname == groups.get(client_group_name, []) | first %}
|
|
{% set ceph_release = hostvars[groups[client_group_name][0]]['ceph_release'] %}
|
|
{% endif %}
|
|
|
|
{% if nb_mon > 0 and inventory_hostname in groups.get(mon_group_name, []) %}
|
|
mon initial members = {% for host in groups[mon_group_name] %}
|
|
{% if hostvars[host]['ansible_fqdn'] is defined and mon_use_fqdn -%}
|
|
{{ hostvars[host]['ansible_fqdn'] }}
|
|
{%- elif hostvars[host]['ansible_hostname'] is defined -%}
|
|
{{ hostvars[host]['ansible_hostname'] }}
|
|
{%- endif %}
|
|
{%- if not loop.last %},{% endif %}
|
|
{% endfor %}
|
|
|
|
osd pool default crush rule = {{ osd_pool_default_crush_rule | default(ceph_osd_pool_default_crush_rule) }}
|
|
{% endif %}
|
|
|
|
fsid = {{ fsid }}
|
|
{% if containerized_deployment %}
|
|
log file = /dev/null
|
|
mon cluster log file = /dev/null
|
|
{% endif %}
|
|
{% if ceph_release not in ['jewel', 'kraken', 'luminous', 'mimic'] %}
|
|
{% set mon_host_v1_suffix = ":6789" %}
|
|
{% set mon_host_v2_suffix = ":3300" %}
|
|
{% endif %}
|
|
mon host = {% if nb_mon > 0 %}
|
|
{% for host in _monitor_addresses -%}
|
|
{% if msgr2_migration | default(False) or not rolling_update %}
|
|
[{{ "v2:" + host.addr + mon_host_v2_suffix }},{{ "v1:" + host.addr + mon_host_v1_suffix }}]
|
|
{%- else -%}
|
|
{{ host.addr }}
|
|
{%- endif %}
|
|
{%- if not loop.last -%},{%- endif %}
|
|
{%- endfor %}
|
|
{% elif nb_mon == 0 and inventory_hostname in groups.get(client_group_name, []) %}
|
|
{{ external_cluster_mon_ips }}
|
|
{% endif %}
|
|
|
|
{% if public_network is defined %}
|
|
public network = {{ public_network | regex_replace(' ', '') }}
|
|
{% endif %}
|
|
{% if cluster_network is defined %}
|
|
cluster network = {{ cluster_network | regex_replace(' ', '') }}
|
|
{% endif %}
|
|
{% if rgw_override_bucket_index_max_shards is defined %}
|
|
rgw override bucket index max shards = {{ rgw_override_bucket_index_max_shards }}
|
|
{% endif %}
|
|
{% if rgw_bucket_default_quota_max_objects is defined %}
|
|
rgw bucket default quota max objects = {{ rgw_bucket_default_quota_max_objects }}
|
|
{% endif %}
|
|
|
|
{% if inventory_hostname in groups.get(client_group_name, []) %}
|
|
[client.libvirt]
|
|
admin socket = {{ rbd_client_admin_socket_path }}/$cluster-$type.$id.$pid.$cctid.asok # must be writable by QEMU and allowed by SELinux or AppArmor
|
|
log file = {{ rbd_client_log_file }} # must be writable by QEMU and allowed by SELinux or AppArmor
|
|
{% endif %}
|
|
|
|
{% if inventory_hostname in groups.get(osd_group_name, []) %}
|
|
{% if osd_objectstore == 'filestore' %}
|
|
[osd]
|
|
osd mkfs type = {{ osd_mkfs_type }}
|
|
osd mkfs options xfs = {{ osd_mkfs_options_xfs }}
|
|
osd mount options xfs = {{ osd_mount_options_xfs }}
|
|
osd journal size = {{ journal_size }}
|
|
{% if filestore_xattr_use_omap != None %}
|
|
filestore xattr use omap = {{ filestore_xattr_use_omap }}
|
|
{% elif osd_mkfs_type == "ext4" %}
|
|
filestore xattr use omap = true
|
|
{# else, default is false #}
|
|
{% endif %}
|
|
{% endif %}
|
|
{% if osd_objectstore == 'bluestore' %}
|
|
{% set _num_osds = num_osds | default(0) | int %}
|
|
[osd]
|
|
{% if is_hci and _num_osds > 0 %}
|
|
{# hci_safety_factor is the safety factor for HCI deployments #}
|
|
{% if ansible_memtotal_mb * 1048576 * hci_safety_factor / _num_osds > osd_memory_target %}
|
|
{% set _osd_memory_target = (ansible_memtotal_mb * 1048576 * hci_safety_factor / _num_osds) | int %}
|
|
{% endif %}
|
|
{% elif _num_osds > 0 %}
|
|
{# non_hci_safety_factor is the safety factor for dedicated nodes #}
|
|
{% if ansible_memtotal_mb * 1048576 * non_hci_safety_factor / _num_osds > osd_memory_target %}
|
|
{% set _osd_memory_target = (ansible_memtotal_mb * 1048576 * non_hci_safety_factor / _num_osds) | int %}
|
|
{% endif %}
|
|
{% endif %}
|
|
osd memory target = {{ _osd_memory_target | default(osd_memory_target) }}
|
|
{% endif %}
|
|
{% endif %}
|
|
|
|
{% if inventory_hostname in groups.get(rgw_group_name, []) %}
|
|
{% for host in groups[rgw_group_name] %}
|
|
{% set _rgw_hostname = hostvars[host]['rgw_hostname'] | default(hostvars[host]['ansible_hostname']) %}
|
|
{# {{ hostvars[host]['rgw_hostname'] }} for backward compatibility, fqdn issues. See bz1580408 #}
|
|
{% if hostvars[host]['rgw_instances'] is defined %}
|
|
{% for instance in hostvars[host]['rgw_instances'] %}
|
|
[client.rgw.{{ _rgw_hostname + '.' + instance['instance_name'] }}]
|
|
host = {{ _rgw_hostname }}
|
|
keyring = /var/lib/ceph/radosgw/{{ cluster }}-rgw.{{ _rgw_hostname + '.' + instance['instance_name'] }}/keyring
|
|
log file = /var/log/ceph/{{ cluster }}-rgw-{{ hostvars[host]['ansible_hostname'] + '.' + instance['instance_name'] }}.log
|
|
rgw frontends = {{ radosgw_frontend_type }} {{ 'port' if radosgw_frontend_type == 'civetweb' else 'endpoint' }}={{ instance['radosgw_address'] }}:{{ instance['radosgw_frontend_port'] }} {{ radosgw_frontend_options }}
|
|
{% endfor %}
|
|
{% endif %}
|
|
{% endfor %}
|
|
{% endif %}
|
|
|
|
{% if inventory_hostname in groups.get(nfs_group_name, []) and inventory_hostname not in groups.get(rgw_group_name, []) %}
|
|
{% for host in groups[nfs_group_name] %}
|
|
{% set _rgw_hostname = hostvars[host]['rgw_hostname'] | default(hostvars[host]['ansible_hostname']) %}
|
|
{% if nfs_obj_gw %}
|
|
[client.rgw.{{ _rgw_hostname }}]
|
|
host = {{ _rgw_hostname }}
|
|
keyring = /var/lib/ceph/radosgw/{{ cluster }}-rgw.{{ _rgw_hostname }}/keyring
|
|
log file = /var/log/ceph/{{ cluster }}-rgw-{{ hostvars[host]['ansible_hostname'] }}.log
|
|
{% endif %}
|
|
{% endfor %}
|
|
{% endif %}
|