我在tasks/main.yml中有以下代码
---
- name: Check if service exists.
shell: "systemctl status {{ service }}"
ignore_errors: yes
register: service_exists
- name: Enable service and start if it exists.
systemd:
name: "{{ service }}"
state: started
enabled: true
when: "could not be found" not in service_exists.stderr' or '"Failed to get properties" not in service_exists.stderr' or '"not-found" not in service_exists.stderr'
我在configure-services.yml中有以下代码
---
- hosts: localhost
become: true
gather_facts: yes
tasks:
- include: tasks/main.yml
with_items: "{{ services }}"
loop_control:
loop_var: service
但是,运行剧本时出现以下错误。
fatal: [localhost]: FAILED! => {"reason": "Syntax Error while loading YAML.\n did not find expected key\n\nThe error appears to have been in '/home/adambirds/Development/ansible-playbooks/system-services/tasks/main.yml': line 12, column 11, but may\nbe elsewhere in the file depending on the exact syntax problem.\n\nThe offending line appears to be:\n\n enabled: true\n when:''\"could not be found\" not in service_exists.stderr' or '\"Failed to get properties\" not in service_exists.stderr' or '\"not-found\" not in service_exists.stderr''\n ^ here\nWe could be wrong, but this one looks like it might be an issue with\nunbalanced quotes. If starting a value with a quote, make sure the\nline ends with the same set of quotes. For instance this arbitrary\nexample:\n\n foo: \"bad\" \"wolf\"\n\nCould be written as:\n\n foo: '\"bad\" \"wolf\"'\n"}
我认为问题出在我的when:声明中,我的目标是在service_exists.stderr中未出现以下任何内容时运行任务:
could not be found
Failed to get properties
not-found
在使用下面@tinita 的建议并将tasks/main.yml更改为以下内容后:
---
- name: Check if service exists.
shell: "systemctl status {{ service }}"
ignore_errors: yes
register: service_exists
- name: Enable service and start if it exists.
systemd:
name: "{{ service }}"
state: started
enabled: true
when: >
"could not be found" not in service_exists.stderr
or "Failed to get properties" not in service_exists.stderr
or "not-found" not in service_exists.stderr
运行 playbook 时出现以下错误:
TASK [Check if service exists.] ***************************************************************************************************************************************************************
fatal: [localhost]: FAILED! => {"changed": true, "cmd": "systemctl status mariadb.service", "delta": "0:00:00.004881", "end": "2018-06-02 16:28:18.849473", "msg": "non-zero return code", "rc": 4, "start": "2018-06-02 16:28:18.844592", "stderr": "Unit mariadb.service could not be found.", "stderr_lines": ["Unit mariadb.service could not be found."], "stdout": "", "stdout_lines": []}
...ignoring
TASK [Enable service and start if it exists.] *************************************************************************************************************************************************
fatal: [localhost]: FAILED! => {"changed": false, "msg": "Could not find the requested service mariadb.service: host"}
to retry, use: --limit @/home/adambirds/Development/ansible-playbooks/system-services/configure-services.retry
PLAY RECAP ************************************************************************************************************************************************************************************
localhost : ok=20 changed=1 unreachable=0 failed=1