2016-12-16 23:24:48 +08:00
|
|
|
|
---
|
|
|
|
|
- name: check if /var/lib/ceph/mon/{{ cluster }}-{{ monitor_name }}/keyring already exists
|
|
|
|
|
stat:
|
|
|
|
|
path: /var/lib/ceph/mon/{{ cluster }}-{{ monitor_name }}/keyring
|
|
|
|
|
register: initial_mon_keyring
|
|
|
|
|
|
|
|
|
|
- name: fail if /var/lib/ceph/mon/{{ cluster }}-{{ monitor_name }}/keyring doesn't exist
|
|
|
|
|
fail:
|
|
|
|
|
msg: "/var/lib/ceph/mon/{{ cluster }}-{{ monitor_name }}/keyring not found"
|
|
|
|
|
when:
|
|
|
|
|
- not initial_mon_keyring.stat.exists
|
|
|
|
|
|
|
|
|
|
- name: get existing initial mon keyring if it already exists but not monitor_keyring.conf in {{ fetch_directory }}
|
|
|
|
|
shell: |
|
|
|
|
|
grep key /var/lib/ceph/mon/{{ cluster }}-{{ monitor_name }}/keyring | sed 's/^.*= //'
|
|
|
|
|
register: monitor_keyring
|
|
|
|
|
when:
|
|
|
|
|
- not monitor_keyring_conf.stat.exists
|
|
|
|
|
|
|
|
|
|
- name: test existing initial mon keyring
|
|
|
|
|
command: ceph --connect-timeout 3 --cluster {{ cluster }} --keyring /var/lib/ceph/mon/{{ cluster }}-{{ monitor_name }}/keyring -n mon. fsid
|
|
|
|
|
register: test_initial_monitor_keyring
|
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
|
|
- name: fail if initial mon keyring found doesn't work
|
|
|
|
|
fail:
|
|
|
|
|
msg: "Initial mon keyring found doesn't work."
|
2017-09-15 06:48:53 +08:00
|
|
|
|
when:
|
|
|
|
|
- test_initial_monitor_keyring.rc != 0
|
2016-12-16 23:24:48 +08:00
|
|
|
|
|
|
|
|
|
- name: write initial mon keyring in {{ fetch_directory }}/monitor_keyring.conf if it doesn't exist
|
syntax: change local_action syntax
Use a nicer syntax for `local_action` tasks.
We used to have oneliner like this:
```
local_action: wait_for port=22 host={{ hostvars[inventory_hostname]['ansible_default_ipv4']['address'] }} state=started delay=10 timeout=500 }}
```
The usual syntax:
```
local_action:
module: wait_for
port: 22
host: "{{ hostvars[inventory_hostname]['ansible_default_ipv4']['address'] }}"
state: started
delay: 10
timeout: 500
```
is nicer and kind of way to keep consistency regarding the whole
playbook.
This also fix a potential issue about missing quotation :
```
Traceback (most recent call last):
File "/tmp/ansible_wQtWsi/ansible_module_command.py", line 213, in <module>
main()
File "/tmp/ansible_wQtWsi/ansible_module_command.py", line 185, in main
rc, out, err = module.run_command(args, executable=executable, use_unsafe_shell=shell, encoding=None, data=stdin)
File "/tmp/ansible_wQtWsi/ansible_modlib.zip/ansible/module_utils/basic.py", line 2710, in run_command
File "/usr/lib64/python2.7/shlex.py", line 279, in split
return list(lex) File "/usr/lib64/python2.7/shlex.py", line 269, in next
token = self.get_token()
File "/usr/lib64/python2.7/shlex.py", line 96, in get_token
raw = self.read_token()
File "/usr/lib64/python2.7/shlex.py", line 172, in read_token
raise ValueError, "No closing quotation"
ValueError: No closing quotation
```
writing `local_action: shell echo {{ fsid }} | tee {{ fetch_directory }}/ceph_cluster_uuid.conf`
can cause trouble because it's complaining with missing quotes, this fix solves this issue.
Fixes: https://bugzilla.redhat.com/show_bug.cgi?id=1510555
Signed-off-by: Guillaume Abrioux <gabrioux@redhat.com>
2018-01-31 16:23:28 +08:00
|
|
|
|
local_action:
|
|
|
|
|
module: shell
|
|
|
|
|
echo {{ monitor_keyring.stdout }} | tee {{ fetch_directory }}/monitor_keyring.conf
|
2016-12-16 23:24:48 +08:00
|
|
|
|
become: false
|
|
|
|
|
when:
|
|
|
|
|
- test_initial_monitor_keyring.rc == 0
|
|
|
|
|
|
|
|
|
|
- name: put initial mon keyring in mon kv store
|
|
|
|
|
command: ceph --cluster {{ cluster }} config-key put initial_mon_keyring {{ monitor_keyring.stdout }}
|
2017-09-15 06:48:53 +08:00
|
|
|
|
when:
|
|
|
|
|
- test_initial_monitor_keyring.rc == 0
|