From de07ba8fbf6ff0ab4fe093c3baa1f8e66be06386 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?S=C3=A9bastien=20Han?= Date: Tue, 6 Dec 2016 15:59:49 +0100 Subject: [PATCH] common: do not regenerate a cluster fsid if cluster exists MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This commit solves the situation where you lost your fetch directory and you are running ansible against an existing cluster. Since no fetch directory is present the file containing the fsid doesn't exist so we are creating a new one. Later the ceph.conf gets updated with a wrong fsid which causes problems for clients and ceph processes. Closes: #1148 Signed-off-by: Sébastien Han --- roles/ceph-common/tasks/facts.yml | 12 ++++++++++++ roles/ceph-common/tasks/main.yml | 14 +++++++++++--- 2 files changed, 23 insertions(+), 3 deletions(-) diff --git a/roles/ceph-common/tasks/facts.yml b/roles/ceph-common/tasks/facts.yml index cef022ffd0..902be2e9ce 100644 --- a/roles/ceph-common/tasks/facts.yml +++ b/roles/ceph-common/tasks/facts.yml @@ -5,6 +5,18 @@ always_run: yes register: ceph_version +- name: is ceph running already? + command: ceph --connect-timeout 3 --cluster {{ cluster }} fsid + changed_when: false + failed_when: false + always_run: yes + register: ceph_current_fsid + delegate_to: "{{ groups.mons[0] }}" + +- set_fact: + fsid: "{{ ceph_current_fsid.stdout }}" + when: ceph_current_fsid.rc == 0 + - set_fact: ceph_version: "{{ ceph_version.stdout.split(' ')[2] }}" diff --git a/roles/ceph-common/tasks/main.yml b/roles/ceph-common/tasks/main.yml index 300b7cbb94..c69c1490fa 100644 --- a/roles/ceph-common/tasks/main.yml +++ b/roles/ceph-common/tasks/main.yml @@ -186,14 +186,22 @@ run_once: true when: cephx or generate_fsid -- name: generate cluster uuid +- name: generate cluster fsid local_action: shell python -c 'import uuid; print(str(uuid.uuid4()))' | tee {{ fetch_directory }}/ceph_cluster_uuid.conf creates="{{ fetch_directory }}/ceph_cluster_uuid.conf" register: cluster_uuid become: false - when: generate_fsid + when: + - generate_fsid + - ceph_current_fsid.rc != 0 + +- name: reuse cluster fsid when cluster is already running + local_action: shell echo {{ fsid }} | tee {{ fetch_directory }}/ceph_cluster_uuid.conf + creates="{{ fetch_directory }}/ceph_cluster_uuid.conf" + become: false + when: ceph_current_fsid.rc == 0 -- name: read cluster uuid if it already exists +- name: read cluster fsid if it already exists local_action: command cat {{ fetch_directory }}/ceph_cluster_uuid.conf removes="{{ fetch_directory }}/ceph_cluster_uuid.conf" changed_when: false