Ansible

Теория: Циклы

Часто в плейбуках нужно выполнить много однотипных задач. Например, установить набор программ или добавить несколько пользователей:

- hosts: all
  tasks:
    - name: install redis server
      ansible.builtin.apt:
        name: redis-server
        state: latest
      become: yes

    - name: install postgresql
      ansible.builtin.apt:
        name: postgresql
        state: latest
      become: yes

    - name: add user testuser1
      ansible.builtin.user:
        name: testuser1
        state: present
        groups: wheel

    - name: add user testuser2
      ansible.builtin.user:
        name: testuser2
        state: present
        groups: root

Мы видим, что с помощью apt сначала устанавливается redis-server, а затем postgresql. В реальном примере список может содержать десятки пакетов. Чтобы упростить этот процесс, Ansible предоставляет механизм под названием циклы. С его помощью можно установить все пакеты в одной таске. Назовем ее install packages:

- hosts: all
  tasks:
    - name: install packages
      ansible.builtin.apt:
        name: "{{ item }}"
        state: latest
      loop:
        - redis-server
        - postgresql
      become: yes

Здесь используется переменная {{ item }} и добавлен ключ loop. Внутри него содержится список элементов, которые будут по очереди подставлены вместо переменной item.

Циклы - очень мощный механизм. Его можно использовать не только с модулем apt, но и с любым другим модулем. Этот модуль будет последовательно отрабатывать таску для каждого элемента.

Правда в случае модуля apt все немного проще. Ему достаточно передать массив в name:

- ansible.builtin.apt:
    state: latest
    name:
      - redis-server
      - postgresql

Еще один вариант использования loop:

- hosts: all
  tasks:
    - name: install packages
      ansible.builtin.apt:
        name: "{{ item }}"
        state: latest
      loop:
        - redis-server
        - postgresql
      become: yes
    - name: add test users
      ansible.builtin.user:
        name: "{{ item.name }}"
        state: present
        groups: "{{ item.groups }}"
      loop:
        - { name: testuser1, groups: wheel }
        - { name: testuser2, groups: root }

Отличие заключается в том, что для добавления пользователя нужны несколько параметров: имя пользователя и группа (возможно, их будет еще больше). Изменения небольшие: мы так же указываем список loop, но внутри него каждый элемент - это хеш, в котором описаны нужные значения. Доступ к значениям item осуществляется через точку.

Рекомендуемые программы