2019-01-12 15:53:00 +00:00
|
|
|
---
|
|
|
|
|
|
|
|
- name: Ensure systemd reloaded
|
|
|
|
service:
|
|
|
|
daemon_reload: yes
|
|
|
|
|
|
|
|
- name: Ensure Matrix services stopped
|
|
|
|
service:
|
|
|
|
name: "{{ item }}"
|
|
|
|
state: stopped
|
|
|
|
with_items: "{{ matrix_systemd_services_list }}"
|
|
|
|
|
|
|
|
- name: Ensure Matrix services started
|
|
|
|
service:
|
|
|
|
name: "{{ item }}"
|
|
|
|
enabled: yes
|
|
|
|
state: started
|
2019-04-03 08:19:06 +00:00
|
|
|
with_items: "{{ matrix_systemd_services_list }}"
|
|
|
|
|
|
|
|
# If we check service state immediately, we may succeed,
|
|
|
|
# because it takes some time for the service to attempt to start and actually fail.
|
|
|
|
#
|
|
|
|
# Waiting too long (30s) may not work for a similar reason,
|
|
|
|
# as we may run into systemd's automatic restart logic retrying the service.
|
|
|
|
- name: Wait a bit, so that services can start (or fail)
|
|
|
|
wait_for:
|
|
|
|
timeout: 5
|
|
|
|
delegate_to: 127.0.0.1
|
|
|
|
become: false
|
|
|
|
|
|
|
|
- name: Populate service facts
|
|
|
|
service_facts:
|
2020-03-28 16:33:35 +00:00
|
|
|
when: ansible_distribution != 'Archlinux'
|
2019-04-03 08:19:06 +00:00
|
|
|
|
|
|
|
- name: Fail if service isn't detected to be running
|
|
|
|
fail:
|
|
|
|
msg: >-
|
|
|
|
{{ item }} was not detected to be running.
|
|
|
|
It's possible that there's a configuration problem or another service on your server interferes with it (uses the same ports, etc.).
|
2019-06-02 22:24:18 +00:00
|
|
|
Try running `systemctl status {{ item }}` and `journalctl -fu {{ item }}` on the server to investigate.
|
2019-04-03 08:19:06 +00:00
|
|
|
with_items: "{{ matrix_systemd_services_list }}"
|
2020-03-28 16:33:35 +00:00
|
|
|
when:
|
|
|
|
- "ansible_facts.services[item + '.service']|default(none) is none or ansible_facts.services[item + '.service'].state != 'running'"
|
|
|
|
- ansible_distribution != 'Archlinux'
|
|
|
|
|
|
|
|
# Currently there is a bug in ansible that renders is incompatible with systemd.
|
|
|
|
# service_facts is not collecting the data successfully.
|
|
|
|
# Therefore iterating here manually
|
|
|
|
- name: Fetch systemd information
|
|
|
|
systemd:
|
|
|
|
name: "{{ item }}"
|
|
|
|
register: systemdstatus
|
|
|
|
with_items: "{{ matrix_systemd_services_list }}"
|
|
|
|
when:
|
|
|
|
- ansible_distribution == 'Archlinux'
|
|
|
|
|
|
|
|
- name: Fail if service isn't detected to be running
|
|
|
|
fail:
|
|
|
|
msg: >-
|
|
|
|
{{ item.item }} was not detected to be running.
|
|
|
|
It's possible that there's a configuration problem or another service on your server interferes with it (uses the same ports, etc.).
|
|
|
|
Try running `systemctl status {{ item.item }}` and `journalctl -fu {{ item.item }}` on the server to investigate.
|
|
|
|
with_items: "{{ systemdstatus.results }}"
|
|
|
|
loop_control:
|
|
|
|
label: "{{ item.name }}"
|
|
|
|
when:
|
|
|
|
#- "ansible_facts.services[item + '.service']|default(none) is none or ansible_facts.services[item + '.service'].state != 'running'"
|
|
|
|
- "item.status['ActiveState'] != 'active'"
|
|
|
|
- "ansible_distribution == 'Archlinux'"
|