2017-09-27 20:13:39 +08:00
|
|
|
---
|
2017-09-28 00:22:15 +08:00
|
|
|
- name: set_fact docker_exec_cmd mds
|
|
|
|
set_fact:
|
|
|
|
docker_exec_cmd: "docker exec ceph-mds-{{ ansible_hostname }}"
|
|
|
|
|
2017-09-27 20:13:39 +08:00
|
|
|
- name: set_fact ceph_config_keys
|
|
|
|
set_fact:
|
|
|
|
ceph_config_keys:
|
|
|
|
- /var/lib/ceph/bootstrap-mds/{{ cluster }}.keyring
|
|
|
|
|
|
|
|
- name: stat for ceph config and keys
|
|
|
|
local_action: stat path={{ fetch_directory }}/{{ fsid }}/{{ item }}
|
|
|
|
with_items: "{{ ceph_config_keys }}"
|
|
|
|
changed_when: false
|
|
|
|
become: false
|
|
|
|
failed_when: false
|
2017-10-25 22:53:34 +08:00
|
|
|
check_mode: no
|
2017-09-27 20:13:39 +08:00
|
|
|
register: statconfig
|
|
|
|
|
|
|
|
- name: try to fetch ceph config and keys
|
|
|
|
copy:
|
|
|
|
src: "{{ fetch_directory }}/{{ fsid }}/{{ item.0 }}"
|
|
|
|
dest: "{{ item.0 }}"
|
|
|
|
owner: root
|
|
|
|
group: root
|
|
|
|
mode: 0644
|
|
|
|
changed_when: false
|
|
|
|
with_together:
|
|
|
|
- "{{ ceph_config_keys }}"
|
|
|
|
- "{{ statconfig.results }}"
|
|
|
|
when: item.1.stat.exists == true
|
|
|
|
|
|
|
|
- name: set selinux permissions
|
|
|
|
shell: |
|
|
|
|
chcon -Rt svirt_sandbox_file_t {{ item }}
|
|
|
|
with_items:
|
|
|
|
- "{{ ceph_conf_key_directory }}"
|
|
|
|
- /var/lib/ceph
|
|
|
|
changed_when: false
|
|
|
|
when: sestatus.stdout != 'Disabled'
|
|
|
|
|
|
|
|
- name: generate systemd unit file
|
|
|
|
become: true
|
|
|
|
template:
|
|
|
|
src: "{{ role_path }}/templates/ceph-mds.service.j2"
|
|
|
|
dest: /etc/systemd/system/ceph-mds@.service
|
|
|
|
owner: "root"
|
|
|
|
group: "root"
|
|
|
|
mode: "0644"
|
|
|
|
|
|
|
|
- name: systemd start mds container
|
|
|
|
systemd:
|
|
|
|
name: ceph-mds@{{ ansible_hostname }}
|
|
|
|
state: started
|
|
|
|
enabled: yes
|
|
|
|
daemon_reload: yes
|
|
|
|
changed_when: false
|
|
|
|
|
|
|
|
- name: wait for mds socket to exist
|
|
|
|
command: "{{ docker_exec_cmd }} stat /var/run/ceph/{{ cluster }}-mds.{{ ansible_hostname }}.asok"
|
|
|
|
register: multi_mds_socket
|
|
|
|
retries: 5
|
|
|
|
delay: 15
|
|
|
|
until: multi_mds_socket.rc == 0
|
|
|
|
|
|
|
|
- name: enable multimds if requested when mon is containerized
|
|
|
|
command: "{{ docker_exec_cmd }} ceph --cluster {{ cluster }} fs set {{ cephfs }} allow_multimds true --yes-i-really-mean-it"
|
|
|
|
changed_when: false
|
|
|
|
when:
|
|
|
|
- mds_allow_multimds
|
|
|
|
|
|
|
|
- name: set max_mds when mon is containerized
|
|
|
|
command: "{{ docker_exec_cmd }} ceph --cluster {{ cluster }} fs set {{ cephfs }} max_mds {{ mds_max_mds }}"
|
|
|
|
changed_when: false
|
|
|
|
when:
|
|
|
|
- mds_allow_multimds
|
|
|
|
- mds_max_mds > 1
|