1

我正在尝试使用 python 脚本执行以下剧本。

playbook = dict(
        name = "Enable Site",
        hosts = [host],
        gather_facts = 'no',
        tasks = [
            dict(action=dict(
                module='find', args=dict(paths="/etc/apache2/sites-enabled")), register='files_found'),
            dict(action=dict(
                module='shell', args="cd /etc/apache2/sites-enabled && a2dissite *"), register='shell_out', when='files_found.matched > 0'),
            dict(action=dict(module='shell', args="a2ensite " + site_name), register='shell_out'),
            dict(action=dict(module='service', args="name='apache2' state='reloaded'"), register='shell_out'),
        ]
    )

该剧本基本上检查是否启用了任何 apache 站点,如果是,则通过从 /etc/apache2/sites-enabled 中删除所有文件来禁用它们。

第二个任务应该在目录/etc/apache2/sites-enabled为空时执行。但是“何时”条件总是被评估为真。即使我写when="False"。也试过when="eval(False)"

4

2 回答 2

0

这个问题相当古老,但您可以找到 ansible 如何解释剧本,但使用您尝试使用的 api:每个实例:

#!/usr/bin/python

import json
from ansible import context
from ansible import constants as C
from ansible.playbook import Playbook
from ansible.parsing.dataloader import DataLoader
from ansible.vars.manager import VariableManager

loader=DataLoader()
variable_manager = VariableManager(loader=loader)


pb = Playbook.load('pb.yml', variable_manager=variable_manager, loader=loader)
print(json.dumps(pb._loader.__dict__['_FILE_CACHE']['/usr/ansible/pb.yml'][0], indent=2))

这将以 json 格式输出剧本。然后你可以将它与 python api 或 ansible-runner 一起使用。

请注意,API 一定会更改,恕不另行通知,因此这可能在未来的版本中不起作用。. 在 RHEL7 上使用 ansible 2.9 进行了测试。

于 2021-10-01T12:15:31.827 回答
0

如果我将您的playbook字典转换为常规的 Ansible 剧本,如下所示:

- name: Enable Site
  hosts:
    - localhost
  gather_facts: no
  tasks:
    - action:
        module: find
        args:
          paths: /etc/apache2/sites-enabled
      register: files_found
    - action:
        module: shell
        args: cd /etc/apache2/sites-enabled && a2dissite *
      register: shell_out
      when: files_found.matched > 0
    - action:
        module: shell
        args: a2ensite 100-mysite.conf
      register: shell_out
    - action:
        module: service
        args: name='apache2' state='reloaded'
      register: shell_out

它似乎按预期运行。也就是说,如果我从一个空/etc/apache2/sites-enabled目录开始,我会看到:

PLAY [Enable Site] *******************************************************************

TASK [find] **************************************************************************
ok: [localhost]

TASK [shell] *************************************************************************
skipping: [localhost]

TASK [shell] *************************************************************************
changed: [localhost]

你可以看到它在那里跳过了第二个 shell 任务。但是,想想你的剧本是做什么的:

  • 它检查目录是否为空
  • 如果不是,它会禁用一切
  • 它将文件安装到目录中

这意味着每次运行此剧本时,它都会清空/etc/apache2/sites-enabled,然后重新启用site_name变量中命名的站点。

于 2020-01-25T17:48:37.687 回答