asynchronous - Ansible 显示任务已更改但任务有条件(创建 : ) and does not actually execute

标签 asynchronous ansible

我的 ansible-playbook 正在运行一些带有异步标签的长时间运行的任务,并且还利用“创建:”条件,因此它只在服务器上运行一次。当我昨天写剧本时,我很确定,当“creates:”标签中设置的日志存在时,任务被跳过了。

不过,每次我运行它时,它现在都显示已更改。

我很困惑,因为我认为我没有做任何更改,并且我想在条件为真时将我注册的变量正确设置为未更改。

ansible-play 的输出(调试部分显示任务已更改:true):

    TASK [singleserver : Install Assure1 SingleServer role] *********************************************************************************************************************************
changed: [crassure1]

TASK [singleserver : Debug] *************************************************************************************************************************************************************
ok: [crassure1] => {
    "msg": {
        "ansible_job_id": "637594935242.28556",
        "changed": true,
        "failed": false,
        "finished": 0,
        "results_file": "/root/.ansible_async/637594935242.28556",
        "started": 1
    }
}

但是如果我检查目标机器上的实际结果文件,它正确地解决了条件并且没有实际执行 shell 脚本,所以任务应该没有改变(显示消息任务被跳过,因为日志存在):

[root@crassure1 assure1]# cat "/root/.ansible_async/637594935242.28556"
{"invocation": {"module_args": {"warn": true, "executable": null, "_uses_shell": true, "strip_empty_ends": true, "_raw_params": "/opt/install/install_command.sh", "removes": null, "argv": null, "creates": "/opt/assure1/logs/SetupWizard.log", "chdir": null, "stdin_add_newline": true, "stdin": null}}, "cmd": "/opt/install/install_command.sh", "changed": false, "rc": 0, "stdout": "skipped, since /opt/assure1/logs/SetupWizard.log exists"}[root@crassure1 assure1]# Connection reset by 172.24.36.123 port 22

我的剧本部分如下所示:

- name: Install Assure1 SingleServer role
  shell:
    #cmd: "/opt/assure1/bin/SetupWizard -a --Depot /opt/install/:a1-local --First --WebFQDN crassure1.tspdata.local --Roles All"
    cmd: "/opt/install/install_command.sh"
  async: 7200
  poll: 0
  register: Assure1InstallWait
  args:
    creates: /opt/assure1/logs/SetupWizard.log

- name: Debug
  debug:
    msg: "{{ Assure1InstallWait }}"

- name: Check on Installation status every 15 minutes
  async_status:
    jid: "{{ Assure1InstallWait.ansible_job_id }}"
  register: job_result
  until: job_result.finished
  retries: 30
  delay: 900
  when: Assure1InstallWait is changed

我是否遗漏了什么,或者这是某种错误?

我受配置的受信任存储库中可用的 Ansible 版本的限制,所以我使用的是 ansible 2.9.25

最佳答案

问:每次运行时模块 shell 显示都会改变

答:在async 模式下,任务不能被立即跳过。首先,模块 shell 必须找出文件 /opt/assure1/logs/SetupWizard.log 是否存在于远程主机上。然后,如果文件存在,模块将决定跳过命令的执行。但是,您异步运行任务。在这种情况下,Ansible 启动模块并返回,而不等待模块完成。这就是注册变量 Assure1InstallWait 所说的。任务已开始但尚未完成。

    "msg": {
        "ansible_job_id": "637594935242.28556",
        "changed": true,
        "failed": false,
        "finished": 0,
        "results_file": "/root/.ansible_async/637594935242.28556",
        "started": 1
    }

设置这样一个任务的决定改变是正确的,我认为是因为远程主机上的执行正在进行。

打印模块异步的注册结果。您会看到,该命令被跳过,因为该文件存在(您已经在远程打印了异步文件)。这里属性 changed 被设置为 false 因为现在我们知道命令没有执行

  job_result:
    ...
    attempts: 1
    changed: false
    failed: false
    finished: 1
    msg: Did not run command since '/tmp/SetupWizard.log' exists
    rc: 0
    ...

关于asynchronous - Ansible 显示任务已更改但任务有条件(创建 : ) and does not actually execute,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70563482/

相关文章:

tomcat - 如何在 Ansible 上运行 tomcat catalina 脚本

模板模块中的 Ansible group_vars

Ansible - 将库存主机和变量读取到 group_vars/all 文件

VB.Net 正确关闭在后台工作程序上运行的异步套接字服务器

javascript - 重定向到另一个页面后循环中的陈旧元素引用

ruby-on-rails - 如何使用 Ansible 检查文件中是否存在行?

ansible - 使用 hash_vault Ansible 插件无法访问 Hashicorp Vault KV 存储版本 2

ios - 无法从像 XMLParser 这样的异步函数调用 Segue

android - 如何在 android 中编写异步内容提供程序

c# - 异步和等待 - 如何维护执行顺序?