From fc3ff58d1892ceb08c75b5b06ddded7361b12d39 Mon Sep 17 00:00:00 2001 From: John Fulton Date: Mon, 28 Mar 2022 15:55:43 -0400 Subject: [PATCH] cephadm support for 'openstack overcloud export ceph' Without this patch 'openstack overcloud export ceph' can only export information from a ceph-ansible deployment as found in the config-download directory. This patch results in the export ceph command looking in the config-download directory for a ceph-ansible or cephadm directory and based on what it finds it generates the a Heat environment with the CephExternalMultiConfig parameter populated. Conflict: tripleoclient/export.py Closes-Bug: #1966772 Depends-On: I9f854377fcd0dfa570d0dc30e34d40826de8656d Change-Id: Idbb2d9270c83ac0e97e0bdb1ea6e2992671f94aa (cherry picked from commit 1952f5a6ee2001b93ecf26c765c4ffaac4e5ca4d) --- tripleoclient/export.py | 58 ++++++++++++++++++++---------- tripleoclient/tests/test_export.py | 3 +- 2 files changed, 42 insertions(+), 19 deletions(-) diff --git a/tripleoclient/export.py b/tripleoclient/export.py index be72ec996..2a5dd0e75 100644 --- a/tripleoclient/export.py +++ b/tripleoclient/export.py @@ -184,41 +184,63 @@ def export_storage_ips(stack, config_download_dir=constants.DEFAULT_WORK_DIR, def export_ceph(stack, cephx, config_download_dir=constants.DEFAULT_WORK_DIR, - mon_ips=[]): + mon_ips=[], config_download_files=[]): # Return a map of ceph data for a list item in CephExternalMultiConfig # by parsing files within the config_download_dir of a certain stack - if len(mon_ips) == 0: - mon_ips = export_storage_ips(stack, config_download_dir) + if len(config_download_files) == 0: + config_download_files = os.listdir(os.path.join( + config_download_dir, stack)) + if 'ceph-ansible' in config_download_files: + if len(mon_ips) == 0: + mon_ips = export_storage_ips(stack, config_download_dir) + external_cluster_mon_ips = str(','.join(mon_ips)) - # Use ceph-ansible group_vars/all.yml to get remaining values - ceph_ansible_all = "ceph-ansible/group_vars/all.yml" - file = os.path.join(config_download_dir, stack, ceph_ansible_all) - with open(file, 'r') as ff: - try: - ceph_data = yaml.safe_load(ff) - except Exception as e: - LOG.error( - _('Could not read file %s') % file) - LOG.error(e) + # Use ceph-ansible group_vars/all.yml to get remaining values + ceph_ansible_all = "ceph-ansible/group_vars/all.yml" + file = os.path.join(config_download_dir, stack, ceph_ansible_all) + with open(file, 'r') as ff: + try: + ceph_data = yaml.safe_load(ff) + except yaml.MarkedYAMLError as e: + LOG.error( + _('Could not read file %s') % file) + LOG.error(e) + cluster = ceph_data['cluster'] + fsid = ceph_data['fsid'] + if 'cephadm' in config_download_files: + ceph_client = "cephadm/ceph_client.yml" + file = os.path.join(config_download_dir, stack, ceph_client) + with open(file, 'r') as ff: + try: + ceph_data = yaml.safe_load(ff) + except yaml.MarkedYAMLError as e: + LOG.error( + _('Could not read file %s') % file) + LOG.error(e) + external_cluster_mon_ips = ceph_data['external_cluster_mon_ips'] + cluster = ceph_data['tripleo_ceph_client_cluster'] + fsid = ceph_data['tripleo_ceph_client_fsid'] + + # set cephx_keys for key in ceph_data['keys']: if key['name'] == 'client.' + str(cephx): cephx_keys = [key] - + # set ceph_conf_overrides ceph_conf_overrides = {} ceph_conf_overrides['client'] = {} ceph_conf_overrides['client']['keyring'] = '/etc/ceph/' \ - + ceph_data['cluster'] \ + + cluster \ + '.client.' + cephx \ + '.keyring' # Combine extracted data into one map to return data = {} - data['external_cluster_mon_ips'] = str(','.join(mon_ips)) + data['external_cluster_mon_ips'] = external_cluster_mon_ips data['keys'] = cephx_keys data['ceph_conf_overrides'] = ceph_conf_overrides - data['cluster'] = ceph_data['cluster'] - data['fsid'] = ceph_data['fsid'] + data['cluster'] = cluster + data['fsid'] = fsid data['dashboard_enabled'] = False return data diff --git a/tripleoclient/tests/test_export.py b/tripleoclient/tests/test_export.py index 0d49b2d7c..4021c2a90 100644 --- a/tripleoclient/tests/test_export.py +++ b/tripleoclient/tests/test_export.py @@ -238,7 +238,8 @@ class TestExport(TestCase): with mock.patch('builtins.open', self.mock_open_ceph_all): data = export.export_ceph('dcn0', 'openstack', config_download_dir='/foo', - mon_ips=['192.168.24.42']) + mon_ips=['192.168.24.42'], + config_download_files=['ceph-ansible']) self.assertEqual(data, expected) self.mock_open_ceph_all.assert_called_once_with( '/foo/dcn0/ceph-ansible/group_vars/all.yml', 'r')