2017-08-04 22:57:46 +08:00
|
|
|
---
|
2019-02-05 07:21:42 +08:00
|
|
|
- name: include create_ceph_initial_dirs.yml
|
|
|
|
include_tasks: create_ceph_initial_dirs.yml
|
2019-05-22 16:02:42 +08:00
|
|
|
when: containerized_deployment | bool
|
2019-02-05 07:21:42 +08:00
|
|
|
|
2019-03-28 16:13:30 +08:00
|
|
|
- name: config file operations related to OSDs
|
|
|
|
when:
|
|
|
|
- inventory_hostname in groups.get(osd_group_name, [])
|
2019-03-29 03:34:48 +08:00
|
|
|
# the rolling_update.yml playbook sets num_osds to the number of currently
|
|
|
|
# running osds
|
2019-05-22 16:02:42 +08:00
|
|
|
- not rolling_update | bool
|
2019-03-28 16:13:30 +08:00
|
|
|
block:
|
2019-01-31 07:07:30 +08:00
|
|
|
- name: count number of osds for lvm scenario
|
|
|
|
set_fact:
|
|
|
|
num_osds: "{{ lvm_volumes | length | int }}"
|
2019-04-01 23:46:15 +08:00
|
|
|
when: lvm_volumes | default([]) | length > 0
|
2019-01-31 07:07:30 +08:00
|
|
|
|
2020-01-10 02:31:57 +08:00
|
|
|
- block:
|
|
|
|
- name: look up for ceph-volume rejected devices
|
|
|
|
ceph_volume:
|
|
|
|
cluster: "{{ cluster }}"
|
|
|
|
action: "inventory"
|
|
|
|
register: rejected_devices
|
|
|
|
environment:
|
|
|
|
CEPH_VOLUME_DEBUG: 1
|
|
|
|
CEPH_CONTAINER_IMAGE: "{{ ceph_docker_registry + '/' + ceph_docker_image + ':' + ceph_docker_image_tag if containerized_deployment else None }}"
|
|
|
|
CEPH_CONTAINER_BINARY: "{{ container_binary }}"
|
|
|
|
PYTHONIOENCODING: utf-8
|
|
|
|
|
|
|
|
- name: set_fact rejected_devices
|
|
|
|
set_fact:
|
|
|
|
_rejected_devices: "{{ _rejected_devices | default([]) + [item.path] }}"
|
|
|
|
with_items: "{{ rejected_devices.stdout | default('{}') | from_json }}"
|
|
|
|
when: "'Used by ceph-disk' in item.rejected_reasons"
|
|
|
|
|
|
|
|
- name: set_fact _devices
|
|
|
|
set_fact:
|
|
|
|
_devices: "{{ devices | difference(_rejected_devices | default([])) }}"
|
|
|
|
|
|
|
|
- name: run 'ceph-volume lvm batch --report' to see how many osds are to be created
|
|
|
|
ceph_volume:
|
|
|
|
cluster: "{{ cluster }}"
|
|
|
|
objectstore: "{{ osd_objectstore }}"
|
|
|
|
batch_devices: "{{ _devices }}"
|
|
|
|
osds_per_device: "{{ osds_per_device | default(1) | int }}"
|
|
|
|
journal_size: "{{ journal_size }}"
|
|
|
|
block_db_size: "{{ block_db_size }}"
|
|
|
|
report: true
|
|
|
|
action: "batch"
|
|
|
|
register: lvm_batch_report
|
|
|
|
environment:
|
|
|
|
CEPH_VOLUME_DEBUG: 1
|
|
|
|
CEPH_CONTAINER_IMAGE: "{{ ceph_docker_registry + '/' + ceph_docker_image + ':' + ceph_docker_image_tag if containerized_deployment else None }}"
|
|
|
|
CEPH_CONTAINER_BINARY: "{{ container_binary }}"
|
|
|
|
PYTHONIOENCODING: utf-8
|
|
|
|
when: _devices | default([]) | length > 0
|
|
|
|
when:
|
|
|
|
- devices | default([]) | length > 0
|
2019-01-31 07:07:30 +08:00
|
|
|
|
|
|
|
- name: set_fact num_osds from the output of 'ceph-volume lvm batch --report'
|
|
|
|
set_fact:
|
2020-01-10 02:31:57 +08:00
|
|
|
num_osds: "{{ ((lvm_batch_report.stdout | default('{}') | from_json).osds | default([]) | length | int) + (_rejected_devices | default([]) | length | int) }}"
|
2019-01-31 07:07:30 +08:00
|
|
|
when:
|
|
|
|
- devices | default([]) | length > 0
|
2020-01-10 02:31:57 +08:00
|
|
|
- (lvm_batch_report.stdout | default('{}') | from_json).changed | default(true) | bool
|
2019-01-31 07:07:30 +08:00
|
|
|
|
|
|
|
- name: run 'ceph-volume lvm list' to see how many osds have already been created
|
|
|
|
ceph_volume:
|
|
|
|
action: "list"
|
|
|
|
register: lvm_list
|
|
|
|
environment:
|
|
|
|
CEPH_VOLUME_DEBUG: 1
|
2019-02-01 03:38:53 +08:00
|
|
|
CEPH_CONTAINER_IMAGE: "{{ ceph_docker_registry + '/' + ceph_docker_image + ':' + ceph_docker_image_tag if containerized_deployment else None }}"
|
2019-01-31 07:07:30 +08:00
|
|
|
CEPH_CONTAINER_BINARY: "{{ container_binary }}"
|
2019-04-02 04:02:28 +08:00
|
|
|
PYTHONIOENCODING: utf-8
|
2019-08-09 06:32:38 +08:00
|
|
|
changed_when: false
|
2019-01-31 07:07:30 +08:00
|
|
|
when:
|
|
|
|
- devices | default([]) | length > 0
|
2020-01-10 02:31:57 +08:00
|
|
|
- not (lvm_batch_report.stdout | default('{}') | from_json).changed | default(false) | bool
|
2019-01-31 07:07:30 +08:00
|
|
|
|
|
|
|
- name: set_fact num_osds from the output of 'ceph-volume lvm list'
|
|
|
|
set_fact:
|
2020-01-10 02:31:57 +08:00
|
|
|
num_osds: "{{ lvm_list.stdout | default('{}') | from_json | length | int }}"
|
2019-01-31 07:07:30 +08:00
|
|
|
when:
|
|
|
|
- devices | default([]) | length > 0
|
2020-01-10 02:31:57 +08:00
|
|
|
- not (lvm_batch_report.stdout | default('{}') | from_json).changed | default(false) | bool
|
2019-01-31 07:07:30 +08:00
|
|
|
|
2017-08-04 22:57:46 +08:00
|
|
|
# ceph-common
|
2019-03-28 16:13:30 +08:00
|
|
|
- name: config file operation for non-containerized scenarios
|
2019-05-22 16:02:42 +08:00
|
|
|
when: not containerized_deployment | bool
|
2019-03-28 16:13:30 +08:00
|
|
|
block:
|
2018-02-21 22:56:32 +08:00
|
|
|
- name: create ceph conf directory
|
2017-08-04 22:57:46 +08:00
|
|
|
file:
|
2018-02-21 22:56:32 +08:00
|
|
|
path: "/etc/ceph"
|
2017-08-04 22:57:46 +08:00
|
|
|
state: directory
|
|
|
|
owner: "ceph"
|
|
|
|
group: "ceph"
|
2018-08-01 20:37:40 +08:00
|
|
|
mode: "{{ ceph_directories_mode | default('0755') }}"
|
2017-08-04 22:57:46 +08:00
|
|
|
|
|
|
|
- name: "generate ceph configuration file: {{ cluster }}.conf"
|
|
|
|
action: config_template
|
|
|
|
args:
|
|
|
|
src: ceph.conf.j2
|
2018-02-21 22:56:32 +08:00
|
|
|
dest: /etc/ceph/{{ cluster }}.conf
|
2017-08-04 22:57:46 +08:00
|
|
|
owner: "ceph"
|
|
|
|
group: "ceph"
|
|
|
|
mode: "0644"
|
2018-03-12 22:13:53 +08:00
|
|
|
config_overrides: "{{ ceph_conf_overrides }}"
|
2017-08-04 22:57:46 +08:00
|
|
|
config_type: ini
|
|
|
|
notify:
|
|
|
|
- restart ceph mons
|
|
|
|
- restart ceph osds
|
|
|
|
- restart ceph mdss
|
|
|
|
- restart ceph rgws
|
2017-10-18 00:28:06 +08:00
|
|
|
- restart ceph mgrs
|
|
|
|
- restart ceph rbdmirrors
|
2019-10-10 04:50:09 +08:00
|
|
|
- restart ceph rbd-target-api-gw
|
2018-06-05 16:43:55 +08:00
|
|
|
|
|
|
|
- name: "ensure fetch directory exists"
|
|
|
|
run_once: true
|
|
|
|
become: false
|
2018-11-01 19:50:31 +08:00
|
|
|
file:
|
2018-06-05 16:43:55 +08:00
|
|
|
path: "{{ fetch_directory }}/{{ fsid }}/etc/ceph"
|
|
|
|
state: directory
|
2018-08-01 20:37:40 +08:00
|
|
|
mode: "{{ ceph_directories_mode | default('0755') }}"
|
2018-11-01 19:50:31 +08:00
|
|
|
delegate_to: localhost
|
2019-05-22 16:02:42 +08:00
|
|
|
when: ceph_conf_local | bool
|
2018-06-05 16:43:55 +08:00
|
|
|
|
|
|
|
- name: "generate {{ cluster }}.conf configuration file locally"
|
2018-11-01 19:50:31 +08:00
|
|
|
config_template:
|
2018-06-05 16:43:55 +08:00
|
|
|
become: false
|
|
|
|
run_once: true
|
2018-11-01 19:50:31 +08:00
|
|
|
delegate_to: localhost
|
2018-06-05 16:43:55 +08:00
|
|
|
args:
|
|
|
|
src: "ceph.conf.j2"
|
|
|
|
dest: "{{ fetch_directory }}/{{ fsid }}/etc/ceph/{{ cluster }}.conf"
|
|
|
|
config_overrides: "{{ ceph_conf_overrides }}"
|
|
|
|
config_type: ini
|
|
|
|
when:
|
|
|
|
- inventory_hostname in groups[mon_group_name]
|
2019-05-22 16:02:42 +08:00
|
|
|
- ceph_conf_local | bool
|
2017-08-04 22:57:46 +08:00
|
|
|
|
2019-03-28 16:13:30 +08:00
|
|
|
- name: config file operations for containerized scenarios
|
2019-05-22 16:02:42 +08:00
|
|
|
when: containerized_deployment | bool
|
2019-03-28 16:13:30 +08:00
|
|
|
block:
|
2017-08-04 22:57:46 +08:00
|
|
|
- name: create a local fetch directory if it does not exist
|
2018-11-01 19:50:31 +08:00
|
|
|
file:
|
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
|
|
|
path: "{{ fetch_directory }}"
|
|
|
|
state: directory
|
2018-11-01 19:50:31 +08:00
|
|
|
delegate_to: localhost
|
2017-08-04 22:57:46 +08:00
|
|
|
changed_when: false
|
|
|
|
become: false
|
|
|
|
run_once: true
|
|
|
|
when:
|
2019-05-22 16:02:42 +08:00
|
|
|
- (cephx or generate_fsid) | bool
|
2018-11-26 21:54:02 +08:00
|
|
|
- ((inventory_hostname in groups.get(mon_group_name, [])) or
|
|
|
|
(groups.get(nfs_group_name, []) | length > 0) and inventory_hostname == groups.get(nfs_group_name, [])[0])
|
2017-08-04 22:57:46 +08:00
|
|
|
|
|
|
|
- name: "generate {{ cluster }}.conf configuration file"
|
|
|
|
action: config_template
|
|
|
|
args:
|
|
|
|
src: "ceph.conf.j2"
|
|
|
|
dest: "{{ ceph_conf_key_directory }}/{{ cluster }}.conf"
|
|
|
|
owner: "root"
|
|
|
|
group: "root"
|
|
|
|
mode: "0644"
|
|
|
|
config_overrides: "{{ ceph_conf_overrides }}"
|
|
|
|
config_type: ini
|
|
|
|
notify:
|
|
|
|
- restart ceph mons
|
|
|
|
- restart ceph osds
|
|
|
|
- restart ceph mdss
|
|
|
|
- restart ceph rgws
|
2017-09-27 08:08:40 +08:00
|
|
|
- restart ceph mgrs
|
2017-10-18 00:28:06 +08:00
|
|
|
- restart ceph rbdmirrors
|
2019-10-10 04:50:09 +08:00
|
|
|
- restart ceph rbd-target-api-gw
|