Skip to content

Commit

Permalink
Replace hosts: localhost by delegate_to: localhost
Browse files Browse the repository at this point in the history
As some users have inventory files with not just ceph hosts, they
uses --limit to target only ceph nodes.
Using "hosts: localhost" in playbooks prevent those tasks being
executed. Using delegate_to with run_once fixes the issue.

Fixes: ceph#170

Signed-off-by: Teoman ONAY <[email protected]>
  • Loading branch information
asm0deuz committed Nov 24, 2023
1 parent badf6b3 commit 51c7707
Show file tree
Hide file tree
Showing 5 changed files with 108 additions and 87 deletions.
64 changes: 33 additions & 31 deletions cephadm-clients.yml
Original file line number Diff line number Diff line change
Expand Up @@ -26,39 +26,41 @@


- name: Confirm local readiness
hosts: localhost
hosts: all
gather_facts: false
tasks:

- name: import_role ceph_defaults
import_role:
name: ceph_defaults

- name: fail if the fsid parameter is missing
fail:
msg: >
You must supply an 'fsid' parameter for the corresponding ceph cluster
when: fsid is undefined

- name: fail if admin group doesn't exist or is empty
fail:
msg: |
You must define a group [admin] in your inventory which provides the
keyring that you want to distribute
when: "'admin' not in groups or groups['admin'] | length < 1"

- name: fail if client_group is NOT in the inventory
fail:
msg: >
Variable client_group '{{ client_group }}' is not defined in the inventory
when: client_group not in groups

- name: fail if keyring variable is missing
fail:
msg: |
You must supply a 'keyring' variable that defines the path to the key
that you want to distribute to your client machines
when: keyring is not defined
- run_once: true
delegate_to: localhost
block:
- name: import_role ceph_defaults
import_role:
name: ceph_defaults

- name: fail if the fsid parameter is missing
fail:
msg: >
You must supply an 'fsid' parameter for the corresponding ceph cluster
when: fsid is undefined

- name: fail if admin group doesn't exist or is empty
fail:
msg: |
You must define a group [admin] in your inventory which provides the
keyring that you want to distribute
when: "'admin' not in groups or groups['admin'] | length < 1"

- name: fail if client_group is NOT in the inventory
fail:
msg: >
Variable client_group '{{ client_group }}' is not defined in the inventory
when: client_group not in groups

- name: fail if keyring variable is missing
fail:
msg: |
You must supply a 'keyring' variable that defines the path to the key
that you want to distribute to your client machines
when: keyring is not defined


- name: Confirm admin host is ready
Expand Down
36 changes: 20 additions & 16 deletions cephadm-purge-cluster.yml
Original file line number Diff line number Diff line change
Expand Up @@ -13,26 +13,28 @@


- name: check local prerequisites are in place
hosts: localhost
hosts: all
gather_facts: false
become: true
any_errors_fatal: true

tasks:
- name: fail if fsid was not provided
fail:
msg: |
You must provide the cluster fsid to be purged.
e.g. ansible-playbook -i <inventory host file> cephadm-purge-cluster.yml -e fsid=<your fsid>
when: fsid is undefined

- name: fail if admin group doesn't exist or is empty
fail:
msg: |
You must define a group [admin] in your inventory and add a node where
admin keyring is present at /etc/ceph/ceph.client.admin.keyring
when: "'admin' not in groups or groups['admin'] | length < 1"

- run_once: true
delegate_to: localhost
block:
- name: fail if fsid was not provided
fail:
msg: |
You must provide the cluster fsid to be purged.
e.g. ansible-playbook -i <inventory host file> cephadm-purge-cluster.yml -e fsid=<your fsid>
when: fsid is undefined

- name: fail if admin group doesn't exist or is empty
fail:
msg: |
You must define a group [admin] in your inventory and add a node where
admin keyring is present at /etc/ceph/ceph.client.admin.keyring
when: "'admin' not in groups or groups['admin'] | length < 1"

- name: check keyring is present on the admin host
hosts: admin[0]
Expand Down Expand Up @@ -96,7 +98,7 @@


- name: confirm whether user really wants to purge the cluster
hosts: localhost
hosts: all
gather_facts: false
become: false

Expand All @@ -110,6 +112,8 @@

tasks:
- name: exit playbook, if user did not mean to purge cluster
run_once: true
delegate_to: localhost
fail:
msg: |
Exiting cephadm-purge-cluster playbook, cluster was NOT purged.
Expand Down
44 changes: 26 additions & 18 deletions rocksdb-resharding.yml
Original file line number Diff line number Diff line change
Expand Up @@ -22,32 +22,39 @@
# rocksdb_sharding_parameters : the rocksdb sharding parameter to set. Default is 'm(3) p(3,0-12) O(3,0-13) L P'.
# docker : bool to be set in order to use docker engine instead. Default is False.

- hosts: localhost
- name: rocksdb-resharding
hosts: all
become: true
gather_facts: false
tasks:
- name: fail if osd_id is not defined
fail:
msg: "you must provide 'osd_id' variable"
when: osd_id is undefined
- name: check prerequisites
run_once: true
delegate_to: localhost
block:
- name: fail if osd_id is not defined
fail:
msg: "you must provide 'osd_id' variable"
when: osd_id is undefined

- name: fail if admin_node is not defined
fail:
msg: "you must pass 'admin_node' variable"
when: admin_node is not defined

- name: fail if osd_id isn't an id
fail:
msg: "osd_id must be an id"
when: not osd_id is regex('^\d+$')

- name: set_fact cephadm_cmd
set_fact:
cephadm_cmd: "cephadm {{ '--docker' if docker | default(False) | bool else '' }} shell ceph"

- name: fail if admin_node is not defined
fail:
msg: "you must pass 'admin_node' variable"
when: admin_node is not defined

- name: test connectivity to admin node
ping:
delegate_to: "{{ admin_node }}"

- name: fail if osd_id isn't an id
fail:
msg: "osd_id must be an id"
when: not osd_id is regex('^\d+$')

- name: set_fact cephadm_cmd
set_fact:
cephadm_cmd: "cephadm {{ '--docker' if docker | default(False) | bool else '' }} shell ceph"
run_once: true

- name: get details about the osd daemon
delegate_to: "{{ admin_node }}"
Expand Down Expand Up @@ -89,6 +96,7 @@

- name: resharding operations
delegate_to: "{{ container_host }}"
run_once: true
block:
- name: check fs consistency with fsck before resharding
command: "{{ ceph_bluestore_tool_cmd }} fsck"
Expand Down
5 changes: 4 additions & 1 deletion validate/insecure-registries.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,14 @@
# SPDX-License-Identifier: Apache-2.0
# Author: Guillaume Abrioux <[email protected]>

- hosts: localhost
- name: insecure_registries
hosts: all
become: false
gather_facts: false
tasks:
- name: fail if insecure_registry is undefined
run_once: true
delegate_to: localhost
fail:
msg: "'insecure_registry' is undefined, it must be set when 'set_insecure_registries' is 'true'."
when:
Expand Down
46 changes: 25 additions & 21 deletions validate/preflight.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,29 +6,33 @@
- ansible.builtin.import_playbook: insecure-registries.yml
when: set_insecure_registries | default(false) | bool

- hosts: localhost
- name: preflight
hosts: all
become: false
gather_facts: false
tasks:
- name: import_role ceph_defaults
import_role:
name: ceph_defaults
- run_once: true
delegate_to: localhost
block:
- name: import_role ceph_defaults
import_role:
name: ceph_defaults

- name: fail when ceph_origin is custom with no repository defined
fail:
msg: "You must define 'ceph_custom_repositories' or 'custom_repo_url' when ceph_origin is 'custom'"
when:
- ceph_origin == 'custom'
- (custom_repo_url is undefined or custom_repo_url == '')
- ceph_custom_repositories is undefined
- name: fail when ceph_origin is custom with no repository defined
fail:
msg: "You must define 'ceph_custom_repositories' or 'custom_repo_url' when ceph_origin is 'custom'"
when:
- ceph_origin == 'custom'
- (custom_repo_url is undefined or custom_repo_url == '')
- ceph_custom_repositories is undefined

- name: fail if baseurl is not defined for ceph_custom_repositories
fail:
msg: "One repository is missing a required parameter: name, description, baseurl."
loop: "{{ ceph_custom_repositories }}"
when:
- ceph_origin == 'custom'
- ceph_custom_repositories is defined
- (item.baseurl is undefined
or item.name is undefined
or item.description is undefined)
- name: fail if baseurl is not defined for ceph_custom_repositories
fail:
msg: "One repository is missing a required parameter: name, description, baseurl."
loop: "{{ ceph_custom_repositories }}"
when:
- ceph_origin == 'custom'
- ceph_custom_repositories is defined
- (item.baseurl is undefined
or item.name is undefined
or item.description is undefined)

0 comments on commit 51c7707

Please sign in to comment.