如何按标记顺序运行Ansible playbook任务

如何按标记顺序运行Ansible playbook任务,ansible,ansible-playbook,Ansible,Ansible Playbook,我想按照--tags中给出的标签顺序运行ansible playbook中的任务 我的游戏手册 --- - hosts: all remote_user: root vars: file_path: '{{filename}}' tasks: - name: Delete user user: name: "{{username}}" state: absent remove: yes

我想按照--tags中给出的标签顺序运行ansible playbook中的任务

我的游戏手册

---
- hosts: all
  remote_user: root
  vars:
    file_path: '{{filename}}'
  tasks:
    - name: Delete user
      user:
        name: "{{username}}"
        state: absent
        remove: yes
      tags:
        - delete_user

    - name: Create user
      user: 
        name: "{{username}}"
        shell: /bin/bash
        groups: "{{groupname}}"
        password: "{{ password |password_hash('sha512') }}"
      tags:
        - create_user

    - name: Add ssh key
      authorized_key:
        user: "{{username}}"
        key: "{{lookup('file', 'file_path')}}"
        exclusive: yes
      tags:
        - add_ssh_key
运行Ansible

ansible-playbook createuser.yml --extra-vars "username=hello password=helloworld groupname=something filename=/path/to/filename" --tags=create_user,add_ssh_key,delete_user
预期产量

TASK: [Create user] *********************************************************** 
changed: [ip address]

TASK: [Add ssh key] *********************************************************** 
changed: [ip address]

TASK: [Delete user] *********************************************************** 
ok: [ip address]
产出来了

TASK: [Delete user] *********************************************************** 
ok: [ip address]

TASK: [Create user] *********************************************************** 
changed: [ip address]

TASK: [Add ssh key] *********************************************************** 
changed: [ip address]
给定标签的顺序

创建用户,添加ssh密钥,删除用户

但按顺序执行


删除用户、创建用户、添加ssh密钥,

这不是标记的用途,在Ansible中无法做到这一点。任务始终按照任务文件中定义的顺序和/或角色添加到剧本/剧本中的顺序执行

如果您想以特定的任务为目标,您可以在应用单个标记的情况下多次调用playbook

ansible-playbook ... --tags=create_user
ansible-playbook ... --tags=add_ssh_key
ansible-playbook ... --tags=delete_user

您可以编写一个简单的bash脚本来实现自动化。(当你有一个更复杂的设置并且必须处理多个标签时,这就是通常的结局)

通常,如果没有给出标签,所有任务都会按照它们在剧本中的顺序执行。我认为,因为您的标记涵盖了剧本中的所有任务,所以它们只是按照没有任何标记的顺序执行。因此,一个解决方案是重新安排剧本中的任务

示例剧本:

  - hosts: localhost

    tasks:
      - name: Third task
        shell:
        tags: "third"

      - name: Second task
        shell:
        tags: "second"

      - name: First task
        shell:
        tags: "first"
- hosts: localhost

  tasks:
    - name: First task
      shell:
      tags: "first"

    - name: Second task
      shell:
      tags: "second"

    - name: Third task
      shell:
      tags: "third"
首次运行:

ansible-playbook -c 'local' test.yml --tags=first,second,third --list-tasks
输出:

playbook: test.yml

play #1 (localhost): localhost        TAGS: []
  tasks:
    Third task        TAGS: [third]
    Second task       TAGS: [second]
    First task        TAGS: [first]
第二轮:

ansible-playbook -c 'local' test.yml --tags=third,first,second --list-tasks
输出(未更改):

现在让我们重新安排剧本中的任务:

  - hosts: localhost

    tasks:
      - name: Third task
        shell:
        tags: "third"

      - name: Second task
        shell:
        tags: "second"

      - name: First task
        shell:
        tags: "first"
- hosts: localhost

  tasks:
    - name: First task
      shell:
      tags: "first"

    - name: Second task
      shell:
      tags: "second"

    - name: Third task
      shell:
      tags: "third"
最终运行:

ansible-playbook -c 'local' test.yml --tags=third,first,second --list-tasks
输出(正确顺序):


通常,如果没有给出标记,所有任务都会按照它们在剧本中的顺序执行

现在,任务在我的环境中按字母顺序执行。(ansible 2.6.0,非最新版本)

我有两个答案:

  • 使用单个标记多次调用playbook
  • 使用
    wait_for
    ()设置任务,以便第二个任务等待第一个任务交付的文件(或其他内容)存在

  • 我同意,ansible标签运行配置的特定部分,而不运行整个剧本。