Ansible 任务失败,即使存在ignore_errors

Aar*_*ire 4 homebrew ansible homebrew-cask

所以我是 Ansible 的新手,但我一直在研究,但找不到任何可以解释这个问题的文章。我创建了一个角色来安装brew cask应用程序,但在运行命令检查应用程序是否已安装时它始终“失败”。

这是任务:

- name: "Check for installed casks (Applications)"
  shell: brew cask list | grep {{ item }}
  register: installed_applications
  with_items: "{{ apps }}"
  when: apps is defined
  ignore_errors: yes
Run Code Online (Sandbox Code Playgroud)

因此,根据我的理解,它将使用我的应用程序列表中的一项运行该命令,因此示例命令为brew cask list | grep keybase,然后将其映射到installed_applications

但是当我运行它时,我最终看到所有应用程序都失败了(没有安装)。这是详细模式下的错误:

failed: [localhost] (item=keybase) => {
    "changed": true,
    "cmd": "brew cask list | grep keybase",
    "delta": "0:00:00.792680",
    "end": "2017-03-03 19:41:05.500378",
    "failed": true,
    "invocation": {
        "module_args": {
            "_raw_params": "brew cask list | grep keybase",
            "_uses_shell": true,
            "chdir": null,
            "creates": null,
            "executable": null,
            "removes": null,
            "warn": false
        },
        "module_name": "command"
    },
    "item": "keybase",
    "rc": 1,
    "start": "2017-03-03 19:41:04.707698",
    "stderr": "",
    "stdout": "",
    "stdout_lines": [],
    "warnings": []
}
Run Code Online (Sandbox Code Playgroud)

如果我手动运行该命令,我只会得到一个空白输出(应该如此),但 Ansible 应该忽略错误,对吗?

Kon*_*rov 5

您的shell任务被标记为失败,因为grep在找不到匹配项时返回非零退出代码。
所以你得到rc: 1failed: true

但是说ignore_errors: yes你告诉 Ansible:即使任务失败也要继续
因此该任务呈红色并标记为失败,但后续任务将被执行。

如果您希望即使 grep 失败任务也是绿色的,请使用bash技巧或使用failed_when条件。你可以在SO上搜索[ansible] grep例如