Add CephDynamicSpec, CephSpecPath, CephOsdSpec, CephSpecFqdn

If the CephDynamicSpec boolean is true, then the
ceph_spec_bootstrap Ansible module will create a
Ceph spec file based on the tripleo-ansible-inventory.

If the CephDynamicSpec boolean is false, then the
deployer may place their own Ceph spec file on the
undercloud at CephSpecPath.

If CephOsdSpec json is set, then it will appear in the
genereated Ceph spec for the 'osd' service_type.

If CephSpecFqdn boolean is true, then the hostname
and hosts of the generated Ceph spec will have their
fully qualified domain name instead of their short
hostname.

Depends-On: I74cb373f1dc94f8a5ef12c0545cfbc0c49abd69b
Change-Id: I3ce3db44706c4b378aa5abc7650ad8478576bf3a
This commit is contained in:
John Fulton 2021-03-07 16:22:14 -05:00 committed by Francesco Pantano
parent d18c6abac7
commit 44d1e2ddd6
No known key found for this signature in database
GPG Key ID: 0458D4D1F41BD75C
2 changed files with 54 additions and 40 deletions

View File

@ -57,16 +57,11 @@ parameter_defaults:
ManagePipeline: true ManagePipeline: true
Debug: true Debug: true
CephAnsibleDisksConfig: CephSpecFqdn: true
osd_objectstore: bluestore CephOsdSpec:
osd_scenario: lvm data_devices:
lvm_volumes: paths:
- data: ceph_lv_data - /dev/ceph_vg/ceph_lv_data
data_vg: ceph_vg
db: ceph_lv_db
db_vg: ceph_vg
wal: ceph_lv_wal
wal_vg: ceph_vg
CephPoolDefaultPgNum: 8 CephPoolDefaultPgNum: 8
CephPoolDefaultSize: 1 CephPoolDefaultSize: 1
CinderRbdExtraPools: altrbd,pool2,pool3 CinderRbdExtraPools: altrbd,pool2,pool3
@ -74,14 +69,6 @@ parameter_defaults:
- name: altrbd - name: altrbd
pg_num: 8 pg_num: 8
rule_name: replicated_rule rule_name: replicated_rule
CephAnsibleExtraConfig:
centos_package_dependencies: []
ceph_osd_docker_memory_limit: '1g'
ceph_mds_docker_memory_limit: '1g'
mon_host_v1: { 'enabled': False }
handler_health_mon_check_retries: 10
handler_health_mon_check_delay: 20
delegate_fact_host: false
#NOTE: These ID's and keys should be regenerated for #NOTE: These ID's and keys should be regenerated for
# a production deployment. What is here is suitable for # a production deployment. What is here is suitable for
# developer and CI testing only. # developer and CI testing only.
@ -121,10 +108,6 @@ parameter_defaults:
key: "AQCwmeRcAAAAABAA6SQU/bGqFjlfLro5KxrB2Q==" key: "AQCwmeRcAAAAABAA6SQU/bGqFjlfLro5KxrB2Q=="
mode: "0600" mode: "0600"
dashboard_enabled: false dashboard_enabled: false
CephAnsiblePlaybookVerbosity: 1
CephAnsibleEnvironmentVariables:
ANSIBLE_SSH_RETRIES: 4
DEFAULT_FORKS: 3
NovaEnableRbdBackend: true NovaEnableRbdBackend: true
CinderEnableRbdBackend: true CinderEnableRbdBackend: true
CinderBackupBackend: ceph CinderBackupBackend: ceph
@ -193,7 +176,6 @@ parameter_defaults:
CephAnsibleSkipClient: false CephAnsibleSkipClient: false
CephConfigPath: "/etc/ceph" CephConfigPath: "/etc/ceph"
CephClientConfigVars: "{{ playbook_dir }}/cephadm/ceph_client.yml" CephClientConfigVars: "{{ playbook_dir }}/cephadm/ceph_client.yml"
CephSpecPath: "/usr/share/ansible/roles/tripleo_cephadm/files/ceph_spec.yaml"
LVMFilterEnabled: true LVMFilterEnabled: true
LVMFilterAllowlist: LVMFilterAllowlist:
- /dev/loop2 - /dev/loop2

View File

@ -301,27 +301,57 @@ parameters:
default: "/home/stack/ceph_client.yml" default: "/home/stack/ceph_client.yml"
type: string type: string
description: The undercloud path where cephadm exports the Ceph Client configuration. description: The undercloud path where cephadm exports the Ceph Client configuration.
CephSpecPath:
default: "/home/stack/ceph_spec.yml"
type: string
description: |
The undercloud path of a valid Ceph orchestrator-cli-service-spec file. If this
file does not exist, then no ceph service spec is not applied by tripleo_cephadm
role.
CephDynamicSpec:
type: boolean
default: false
description: |
If true tripleo_cephadm role will build a orchestrator-cli-service-spec file
based on the data found in the inventory (which is based on composable roles).
If a valid CephSpecPath exists then the dynamic spec is created and applied
first and then the CephSpecPath is applied.
CephAnsibleSkipClient: CephAnsibleSkipClient:
description: | description: |
This boolean (when true) prevents the ceph-ansible client role execution This boolean (when true) prevents the ceph-ansible client role execution
by adding the ceph-ansible tag 'ceph_client' to the --skip-tags list. by adding the ceph-ansible tag 'ceph_client' to the --skip-tags list.
type: boolean type: boolean
default: true default: true
CephDynamicSpec:
type: boolean
default: true
description: |
If true the tripleo_run_cephadm role will build an orchestrator-cli-service-spec
file based on the data found in the inventory (which is based on composable roles)
by using the ceph_spec_bootstrap Ansible module in tripleo-ansible.
CephSpecPath:
default: "{{ playbook_dir }}/cephadm/ceph_spec.yaml"
type: string
description: |
The path on the undercloud to a valid Ceph orchestrator CLI service spec file.
If you do not want the spec to be generated automatically and instead prefer
to supply your own spec, then place your spec at this path on the undercloud
and set CephDynamicSpec to false. If CephDynamicSpec is true and CephSpecPath
is set to a valid path, then the spec will be created at that path before it
is used to deploy Ceph. By default the spec will be created by config-download
in config-download/<stack>/cephadm/ceph_spec.yaml.
CephOsdSpec:
description: |
If CephDynamicSpec is true, then any valid OSD service specification set in
CephOsdSpec will appear in the genereated Ceph spec for the 'osd' service_type.
Replaces CephAnsibleDisksConfig. This parameter has no effect if CephDynamicSpec
is false. Use this paramter to override the default of using all available block
devices as data_devices. See the Ceph documentation for cephadm drivegroups.
Exclude service_type, service_id, and placement from this parameter. In the
example below all rotating devices will be data devices and all non-rotating
devices will be used as shared devices (wal, db).
CephOsdSpec:
data_devices:
rotational: 1
db_devices:
rotational: 0
type: json
default:
data_devices:
all: true
CephSpecFqdn:
default: false
type: boolean
description: |
If both CephDynamicSpec and CephSpecFqdn are true, then the hostname and
hosts of the generated Ceph spec will have their fully qualified domain
name instead of their short hostname. This parameter has no effect if
CephDynamicSpec is false.
parameter_groups: parameter_groups:
- label: deprecated - label: deprecated
@ -512,8 +542,6 @@ resources:
tripleo_ceph_client_vars: {get_param: CephClientConfigVars} tripleo_ceph_client_vars: {get_param: CephClientConfigVars}
tripleo_cephadm_dashboard_enabled: {get_param: CephEnableDashboard} tripleo_cephadm_dashboard_enabled: {get_param: CephEnableDashboard}
cephfs: {get_param: ManilaCephFSShareBackendName} cephfs: {get_param: ManilaCephFSShareBackendName}
tripleo_cephadm_spec_ansible_host: {get_param: CephSpecPath}
tripleo_cephadm_dynamic_spec: {get_param: CephDynamicSpec}
tripleo_cephadm_container_ns: {get_attr: [ContainerImageUrlParts, value, host]} tripleo_cephadm_container_ns: {get_attr: [ContainerImageUrlParts, value, host]}
tripleo_cephadm_container_image: {get_attr: [ContainerImageUrlParts, value, image]} tripleo_cephadm_container_image: {get_attr: [ContainerImageUrlParts, value, image]}
tripleo_cephadm_container_tag: {get_attr: [ContainerImageUrlParts, value, image_tag]} tripleo_cephadm_container_tag: {get_attr: [ContainerImageUrlParts, value, image_tag]}
@ -570,6 +598,10 @@ outputs:
manila_pools: {get_attr: [CephManilaPoolVars, value, vars]} manila_pools: {get_attr: [CephManilaPoolVars, value, vars]}
ceph_keys: {get_attr: [CephKeyVars, value, vars]} ceph_keys: {get_attr: [CephKeyVars, value, vars]}
ceph_config_overrides: {get_param: CephConfigOverrides} ceph_config_overrides: {get_param: CephConfigOverrides}
tripleo_run_cephadm_spec_path: {get_param: CephSpecPath}
tripleo_cephadm_dynamic_spec: {get_param: CephDynamicSpec}
ceph_spec_fqdn: {get_param: CephSpecFqdn}
ceph_osd_spec: {get_param: CephOsdSpec}
ceph_default_overrides: ceph_default_overrides:
if: if:
- msgr_secure_mode - msgr_secure_mode