mirror of https://github.com/ceph/ceph-ansible.git
70 lines
3.1 KiB
YAML
70 lines
3.1 KiB
YAML
---
|
|
- name: create and copy client.crash keyring
|
|
when: cephx | bool
|
|
block:
|
|
- name: create client.crash keyring
|
|
ceph_key:
|
|
name: "client.crash"
|
|
caps: "{{ {'mon': 'allow profile crash', 'mgr': 'allow profile crash'} }}"
|
|
cluster: "{{ cluster }}"
|
|
dest: "{{ ceph_conf_key_directory }}"
|
|
import_key: True
|
|
mode: "{{ ceph_keyring_permissions }}"
|
|
owner: "{{ ceph_uid if containerized_deployment else 'ceph' }}"
|
|
group: "{{ ceph_uid if containerized_deployment else 'ceph' }}"
|
|
environment:
|
|
CEPH_CONTAINER_IMAGE: "{{ ceph_docker_registry + '/' + ceph_docker_image + ':' + ceph_docker_image_tag if containerized_deployment else None }}"
|
|
CEPH_CONTAINER_BINARY: "{{ container_binary }}"
|
|
delegate_to: "{{ groups.get(mon_group_name, [])[0] }}"
|
|
run_once: True
|
|
|
|
- name: get keys from monitors
|
|
command: "{{ hostvars[groups[mon_group_name][0]]['container_exec_cmd'] | default('') }} ceph --cluster {{ cluster }} auth get client.crash"
|
|
register: _crash_keys
|
|
delegate_to: "{{ groups.get(mon_group_name)[0] }}"
|
|
run_once: true
|
|
|
|
- name: get a list of node where the keyring should be copied
|
|
set_fact:
|
|
list_target_node: "{{ list_target_node | default([]) | union(((groups.get('all') | difference(groups.get(grafana_server_group_name, []) + groups.get(client_group_name, []) + groups.get(nfs_group_name, []) + groups.get(iscsi_gw_group_name, []))) + groups.get(item, [])) | unique) }}"
|
|
run_once: True
|
|
with_items:
|
|
- "{{ mon_group_name if groups.get(mon_group_name, []) | length > 0 else [] }}"
|
|
- "{{ osd_group_name if groups.get(osd_group_name, []) | length > 0 else [] }}"
|
|
- "{{ mds_group_name if groups.get(mds_group_name, []) | length > 0 else [] }}"
|
|
- "{{ rgw_group_name if groups.get(rgw_group_name, []) | length > 0 else [] }}"
|
|
- "{{ rbdmirror_group_name if groups.get(rbdmirror_group_name, []) | length > 0 else [] }}"
|
|
- "{{ mgr_group_name if groups.get(mgr_group_name, []) | length > 0 else [] }}"
|
|
|
|
- name: copy ceph key(s) if needed
|
|
copy:
|
|
dest: "{{ ceph_conf_key_directory }}/{{ cluster }}.client.crash.keyring"
|
|
content: "{{ _crash_keys.stdout + '\n' }}"
|
|
owner: "{{ ceph_uid if containerized_deployment else 'ceph' }}"
|
|
group: "{{ ceph_uid if containerized_deployment else 'ceph' }}"
|
|
mode: "{{ ceph_keyring_permissions }}"
|
|
with_items: "{{ list_target_node }}"
|
|
delegate_to: "{{ item }}"
|
|
run_once: True
|
|
|
|
- name: start ceph-crash daemon
|
|
when: containerized_deployment | bool
|
|
block:
|
|
- name: create /var/lib/ceph/crash/posted
|
|
file:
|
|
path: /var/lib/ceph/crash/posted
|
|
state: directory
|
|
mode: '0755'
|
|
owner: "{{ ceph_uid }}"
|
|
group: "{{ ceph_uid }}"
|
|
|
|
- name: include_tasks systemd.yml
|
|
include_tasks: systemd.yml
|
|
|
|
- name: start the ceph-crash service
|
|
systemd:
|
|
name: "{{ 'ceph-crash@' + ansible_hostname if containerized_deployment | bool else 'ceph-crash.service' }}"
|
|
state: started
|
|
enabled: yes
|
|
masked: no
|
|
daemon_reload: yes |