Switch to ceph-ansible stable-8.0
This patch includes the openstack specific pool configuration that previously was in ceph-ansible, and also adds a playbook to configure ceph pools and distribute the keys to all monitor hosts. Co-Authored-By: Damian Dabrowski <damian.dabrowski@cleura.com> Change-Id: Ic55daf6ba7fdb47525ee1913f70e87296383866d
This commit is contained in:
		
							
								
								
									
										19
									
								
								 releasenotes/notes/ceph-ansible-8-3923428844537c1b.yaml 
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								 releasenotes/notes/ceph-ansible-8-3923428844537c1b.yaml 
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | |||||||
|  | --- | ||||||
|  | features: | ||||||
|  |   - | | ||||||
|  |     The external dependancy ceph-ansible is upgraded to version 8.0 and | ||||||
|  |     brings in significant changes within the ceph-ansible project. Deployers | ||||||
|  |     using OpenStack-Ansible are reminded that the ceph-ansible integration | ||||||
|  |     with OSA is primarily a test fixture and production deployments should | ||||||
|  |     ideally deploy an independant ceph cluster. The upgrade between releases | ||||||
|  |     of ceph-ansible is not tested by the OpenStack-Ansible project. | ||||||
|  | upgrade: | ||||||
|  |   - | | ||||||
|  |     The external dependancy ceph-ansible is upgraded to version 8.0 and | ||||||
|  |     brings in significant changes within the ceph-ansible project. | ||||||
|  |     Any deployments with important data held in a ceph cluster deployed | ||||||
|  |     using the OpenStack-Ansible integration with ceph-ansible should | ||||||
|  |     independantly verify that upstream changes in ceph-ansible result | ||||||
|  |     in a successful upgrade. This could undertaken in a test or staging | ||||||
|  |     environment. The upgrade between releases of ceph-ansible is not | ||||||
|  |     tested by the OpenStack-Ansible project. | ||||||
| @@ -333,6 +333,6 @@ | |||||||
| - name: ceph-ansible | - name: ceph-ansible | ||||||
|   scm: git |   scm: git | ||||||
|   src: https://github.com/ceph/ceph-ansible |   src: https://github.com/ceph/ceph-ansible | ||||||
|   version: stable-7.0 |   version: stable-8.0 | ||||||
|   trackbranch: stable-7.0 |   trackbranch: stable-8.0 | ||||||
|   shallow_since: '2024-05-15' |   shallow_since: '2024-05-15' | ||||||
|   | |||||||
| @@ -1,8 +1,9 @@ | |||||||
| --- | --- | ||||||
|  | ceph_rgw_client_name: "client.rgw.{{ rgw_zone | default('default') }}.{{ hostvars[inventory_hostname]['ansible_facts']['hostname']}}.rgw0" | ||||||
| ceph_conf_overrides_rgw: |- | ceph_conf_overrides_rgw: |- | ||||||
|   {{ |   {{ | ||||||
|     { |     { | ||||||
|       'client.rgw.' ~ hostvars[inventory_hostname]['ansible_facts']['hostname'] ~ '.rgw0': { |       ceph_rgw_client_name: { | ||||||
|         'rgw_keystone_url': keystone_service_adminuri, |         'rgw_keystone_url': keystone_service_adminuri, | ||||||
|         'rgw_keystone_api_version': 3, |         'rgw_keystone_api_version': 3, | ||||||
|         'rgw_keystone_admin_user': radosgw_admin_user, |         'rgw_keystone_admin_user': radosgw_admin_user, | ||||||
|   | |||||||
| @@ -47,3 +47,33 @@ libntirpc_stable_deb_repo: http://ppa.launchpad.net/nfs-ganesha/libntirpc-5/ubun | |||||||
| ntp_service_enabled: False | ntp_service_enabled: False | ||||||
|  |  | ||||||
| dashboard_enabled: True | dashboard_enabled: True | ||||||
|  |  | ||||||
|  | openstack_glance_pool: | ||||||
|  |   name: "images" | ||||||
|  |   application: "rbd" | ||||||
|  | openstack_cinder_pool: | ||||||
|  |   name: "volumes" | ||||||
|  |   application: "rbd" | ||||||
|  | openstack_nova_pool: | ||||||
|  |   name: "vms" | ||||||
|  |   application: "rbd" | ||||||
|  | openstack_cinder_backup_pool: | ||||||
|  |   name: "backups" | ||||||
|  |   application: "rbd" | ||||||
|  | openstack_gnocchi_pool: | ||||||
|  |   name: "metrics" | ||||||
|  |   application: "rbd" | ||||||
|  | openstack_cephfs_data_pool: | ||||||
|  |   name: "manila_data" | ||||||
|  |   application: "cephfs" | ||||||
|  | openstack_cephfs_metadata_pool: | ||||||
|  |   name: "manila_metadata" | ||||||
|  |   application: "cephfs" | ||||||
|  | openstack_pools: | ||||||
|  |   - "{{ openstack_glance_pool }}" | ||||||
|  |   - "{{ openstack_cinder_pool }}" | ||||||
|  |   - "{{ openstack_nova_pool }}" | ||||||
|  |   - "{{ openstack_cinder_backup_pool }}" | ||||||
|  |   - "{{ openstack_gnocchi_pool }}" | ||||||
|  |   - "{{ openstack_cephfs_data_pool }}" | ||||||
|  |   - "{{ openstack_cephfs_metadata_pool }}" | ||||||
|   | |||||||
| @@ -15,7 +15,11 @@ | |||||||
|  |  | ||||||
| - name: Gather ceph-mon facts | - name: Gather ceph-mon facts | ||||||
|   hosts: ceph-mon |   hosts: ceph-mon | ||||||
|   gather_facts: "{{ osa_gather_facts | default(True) }}" |   gather_facts: false | ||||||
|  |   tasks: | ||||||
|  |     - name: Refresh all_addresses facts | ||||||
|  |       setup: | ||||||
|  |         gather_subset: "all_ipv4_addresses,all_ipv6_addresses" | ||||||
|   tags: |   tags: | ||||||
|     - always |     - always | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										61
									
								
								playbooks/ceph-pools.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								playbooks/ceph-pools.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,61 @@ | |||||||
|  | - name: Create ceph pools | ||||||
|  |   hosts: "{{ groups['ceph-mon'][0] | default([]) }}" | ||||||
|  |   user: root | ||||||
|  |   gather_facts: false | ||||||
|  |   vars: | ||||||
|  |     is_metal: "{{ properties.is_metal|default(false) }}" | ||||||
|  |   vars_files: | ||||||
|  |     - "defaults/{{ install_method }}_install.yml" | ||||||
|  |   roles: | ||||||
|  |     - role: ceph-defaults | ||||||
|  |       tags: | ||||||
|  |         - skip_ansible_lint | ||||||
|  |   tasks: | ||||||
|  |     - name: Create openstack pool(s) | ||||||
|  |       ceph_pool: | ||||||
|  |         name: "{{ item.name }}" | ||||||
|  |         cluster: "{{ cluster }}" | ||||||
|  |         pg_num: "{{ item.pg_num | default(omit) }}" | ||||||
|  |         pgp_num: "{{ item.pgp_num | default(omit) }}" | ||||||
|  |         size: "{{ item.size | default(omit) }}" | ||||||
|  |         min_size: "{{ item.min_size | default(omit) }}" | ||||||
|  |         pool_type: "{{ item.type | default('replicated') }}" | ||||||
|  |         rule_name: "{{ item.rule_name | default(omit) }}" | ||||||
|  |         erasure_profile: "{{ item.erasure_profile | default(omit) }}" | ||||||
|  |         pg_autoscale_mode: "{{ item.pg_autoscale_mode | default(omit) }}" | ||||||
|  |         target_size_ratio: "{{ item.target_size_ratio | default(omit) }}" | ||||||
|  |         application: "{{ item.application | default(omit) }}" | ||||||
|  |       with_items: "{{ openstack_pools }}" | ||||||
|  |  | ||||||
|  |     - name: Generate keys | ||||||
|  |       ceph_key: | ||||||
|  |         name: "{{ item.name }}" | ||||||
|  |         caps: "{{ item.caps }}" | ||||||
|  |         secret: "{{ item.key | default('') }}" | ||||||
|  |         cluster: "{{ cluster }}" | ||||||
|  |         mode: "{{ item.mode | default(ceph_keyring_permissions) }}" | ||||||
|  |       with_items: "{{ openstack_keys }}" | ||||||
|  |       no_log: "{{ no_log_on_ceph_key_tasks }}" | ||||||
|  |  | ||||||
|  |     - name: Get keys from monitors | ||||||
|  |       ceph_key: | ||||||
|  |         name: "{{ item.name }}" | ||||||
|  |         cluster: "{{ cluster }}" | ||||||
|  |         output_format: plain | ||||||
|  |         state: info | ||||||
|  |       register: _osp_keys | ||||||
|  |       with_items: "{{ openstack_keys }}" | ||||||
|  |       no_log: "{{ no_log_on_ceph_key_tasks }}" | ||||||
|  |  | ||||||
|  |     - name: Distribute ceph keys to all mons | ||||||
|  |       ansible.builtin.copy: | ||||||
|  |         dest: "/etc/ceph/{{ cluster }}.{{ item.0.item.name }}.keyring" | ||||||
|  |         content: "{{ item.0.stdout + '\n' }}" | ||||||
|  |         owner: 'ceph' | ||||||
|  |         group: 'ceph' | ||||||
|  |         mode: "{{ item.0.item.mode | default(ceph_keyring_permissions) }}" | ||||||
|  |       with_nested: | ||||||
|  |         - "{{ _osp_keys.results }}" | ||||||
|  |         - "{{ groups['ceph-mon'] }}" | ||||||
|  |       delegate_to: "{{ item.1 }}" | ||||||
|  |       no_log: "{{ no_log_on_ceph_key_tasks }}" | ||||||
| @@ -46,6 +46,9 @@ | |||||||
| - name: Importing ceph-install playbook | - name: Importing ceph-install playbook | ||||||
|   import_playbook: ceph-install.yml |   import_playbook: ceph-install.yml | ||||||
|  |  | ||||||
|  | - name: Importing ceph-pools playbook | ||||||
|  |   import_playbook: ceph-pools.yml | ||||||
|  |  | ||||||
| - name: Importing ceph-nfs-install playbook | - name: Importing ceph-nfs-install playbook | ||||||
|   import_playbook: ceph-nfs-install.yml |   import_playbook: ceph-nfs-install.yml | ||||||
|  |  | ||||||
|   | |||||||
| @@ -15,7 +15,6 @@ | |||||||
|  |  | ||||||
| ## ceph-ansible AIO settings | ## ceph-ansible AIO settings | ||||||
| is_hci: true | is_hci: true | ||||||
| common_single_host_mode: true |  | ||||||
| monitor_interface: "{{ ('metal' in bootstrap_host_scenarios_expanded) | ternary('br-storage', 'eth2') }}" # Storage network in the AIO | monitor_interface: "{{ ('metal' in bootstrap_host_scenarios_expanded) | ternary('br-storage', 'eth2') }}" # Storage network in the AIO | ||||||
| public_network: "{{ (storage_range ~ '.0/' ~ netmask) | ansible.utils.ipaddr('net') }}" | public_network: "{{ (storage_range ~ '.0/' ~ netmask) | ansible.utils.ipaddr('net') }}" | ||||||
| journal_size: 100 | journal_size: 100 | ||||||
| @@ -23,6 +22,7 @@ osd_scenario: collocated | |||||||
| ceph_conf_overrides_custom: | ceph_conf_overrides_custom: | ||||||
|   global: |   global: | ||||||
|     mon_max_pg_per_osd: 500 |     mon_max_pg_per_osd: 500 | ||||||
|  |     osd_crush_chooseleaf_type: 0 | ||||||
| openstack_config: true # Ceph ansible automatically creates pools & keys | openstack_config: true # Ceph ansible automatically creates pools & keys | ||||||
| cinder_default_volume_type: aio_ceph | cinder_default_volume_type: aio_ceph | ||||||
| glance_ceph_client: glance | glance_ceph_client: glance | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Jonathan Rosser
					Jonathan Rosser