Ansible Builder#

Ansible Builder – это инструмент командной строки, предназначенный для создания образов среды исполнения (EE, execution environment) с использованием метаданных, указанных в специальном файле определения среды исполнения.

Для управления средами исполнения (контейнерами) рекомендуется использовать Podman.

Установка#

Для установки Ansible Builder выполните следующие действия:

  1. Подключите репозиторий Astra Automation.

    Инструкция по подключению репозитория
    1. В каталоге /etc/apt/sources.list.d/ создайте файл astra-automation.list со ссылкой на репозиторий Astra Automation:

      deb https://dl.astralinux.ru/aa/aa-debs-for-alse-1.7 <version> main
      

      Вместо <version> необходимо подставить версию устанавливаемой платформы, например, 1.1-upd1.

      Доступные версии продукта опубликованы в таблице История обновлений.

    2. Обновите список доступных пакетов:

      sudo apt update
      
  2. Установите пакет ansible-builder:

    sudo apt install ansible-builder --yes
    
  3. Установите Podman (рекомендуется) или Docker.

    Важно

    Для управления средами исполнения (контейнерами) рекомендуется использовать Podman. Необходимо учесть, что для корректной работы Podman следует провести дополнительные настройки.

  4. При использовании Docker для корректной работы ansible-builder добавьте активного пользователя в группу docker:

    sudo usermod -aG docker $USER && newgrp docker
    

Установка при отсутствии доступа к интернету описана в документе Инструменты.

Этапы сборки#

Ansible Builder выполняет несколько этапов при запуске инструмента контейнеризации для создания образа контейнера:

  1. Base: использует Docker или Podman для загрузки базового образа, который был определен в файле определения среды исполнения, затем устанавливает версию Python (если она определена и отличается от всех версий Python в базовом образе), pip, ansible-runner и ansible-core или ansible. Все три последующих этапа сборки строятся на выводе этапа Base.

  2. Galaxy: загружает определенные в файле определения среды исполнения коллекции с Galaxy и сохраняет их локально.

  3. Builder: загружает Python-пакеты и системные пакеты, определенные в файле определения среды исполнения, и сохраняет их локально.

  4. Final: производит окончательную сборку образа.

Если необходима настройка размера разделяемой памяти (--shm-size) во время сборки среды исполнения, рекомендуется использовать Docker.

Файл определения среды исполнения#

Файл определения среды исполнения (EE definition) определяет содержимое, которое будет включено в образ контейнера. По умолчанию этот файл называется execution-environment.yml или execution-environment.yaml и может содержать следующие разделы:

  • version;

  • build_arg_defaults;

  • dependencies;

  • images;

  • additional_build_files;

  • additional_build_steps;

  • options.

Пример заполнения файла определения среды исполнения:

---
version: 3

build_arg_defaults:
  ANSIBLE_GALAXY_CLI_COLLECTION_OPTS: '--pre'

dependencies:
  ansible_core:
    package_pip: ansible-core==2.15.6
  ansible_runner:
    package_pip: ansible-runner
   galaxy: requirements.yml
   python:
     - six
     - psutil
   system: bindep.txt
   exclude:
     python:
       - docker
     system:
       - python3-Cython

images:
  base_image:
    name: aa-cr.artifactory.astralinux.ru/aa-creator-ee:0.1.0

additional_build_files:
    - src: files/ansible.cfg
      dest: configs

additional_build_steps:
  prepend_base:
    - RUN echo This is a prepend base command!

  prepend_galaxy:
    - COPY _build/configs/ansible.cfg /etc/ansible/ansible.cfg

  prepend_final: |
    RUN whoami
    RUN cat /etc/os-release
  append_final:
    - RUN echo This is a post-install command!
    - RUN ls -la /etc

Версия#

Целочисленное значение, которое задает версию схемы файла определения среды исполнения. Значение по умолчанию – 1. При использовании Ansible Builder версии 3.x файл начинается со следующих строк:

---
version: 3

Аргументы сборки#

Раздел build_arg_defaults файла определения – это словарь, ключами которого являются названия аргументов Ansible Builder, для которых назначены значения по умолчанию.

Аргументы сборки:

  • ANSIBLE_GALAXY_CLI_COLLECTION_OPTS;

  • ANSIBLE_GALAXY_CLI_ROLE_OPTS;

  • PKGMGR_PRESERVE_CACHE.

Подробное описание аргументов см. в справочных данных.

Примечание

Значения, заданные с помощью аргумента --build-arg, имеют более высокий приоритет.

Значения, указанные в build_arg_defaults, будут сохранены в Containerfile (файл определения образа для Podman). Эти значения будут использованы при сборке путем прямого вызова утилиты podman, например:

podman build .

Зависимости#

В разделе dependencies указываются пакеты и библиотеки, которые необходимо установить в конечный образ.

Возможные параметры:

  • ansible_core;

  • ansible_runner;

  • galaxy;

  • python;

  • python_interpreter;

  • system;

  • exclude.

ansible_core#

Версия пакета ansible-core, который необходимо установить. Значение для pip, может быть в любом формате, поддерживаемом pip.

Пример заполнения:

ansible_core:
    package_pip: ansible-core
ansible_core:
    package_pip: ansible-core==2.15.6
ansible_core:
    package_pip: https://github.com/example_user/ansible/archive/refs/heads/ansible.tar.gz

ansible_runner#

Версия пакета ansible_runner, которую нужно установить.

Пример заполнения:

ansible_runner:
    package_pip: ansible-runner
ansible_runner:
    package_pip: ansible-runner==2.3.2
ansible_runner:
    package_pip: https://github.com/example_user/ansible-runner/archive/refs/heads/ansible-runner.tar.gz

galaxy#

Параметр galaxy указывает на файл зависимостей Ansible для следующей ​команды:

ansible-galaxy collection install -r <requirements>

<requirements> – абсолютный или относительный путь к файлу зависимостей Ansible. Относительный путь начинается от каталога, содержащего файл определения среды исполнения.

Рекомендуемое название файла зависимостей Ansible – requirements.yml.

Пример содержимого файла зависимостей Ansible:

collections:
  - geerlingguy.java
  - kubernetes.core

Python#

Параметр python указывает на файл зависимостей Python для следующей команды:

pip install -r <requirements>

<requirements> – абсолютный или относительный путь к файлу зависимостей Python. Относительный путь начинается от каталога, содержащего файл определения среды исполнения.

Рекомендуемое название файла зависимостей Python – requirements.txt.

Содержимое файла зависимостей Python должно удовлетворять требованиям менеджера пакетов PIP.

python_interpreter#

Параметр определяет название системного пакета Python, который будет установлен ( package_system), или путь к интерпретатору Python, который будет использоваться ( python_path).

Пример заполнения:

python_interpreter:
    package_system: "python310"
    python_path: "/usr/bin/python3.10"

system#

Параметр определяет системные пакеты в формате bindep (binary dependency), которые необходимо установить. Это может быть название файла или список требований.

Пример заполнения:

system: bindep.txt

exclude#

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

Возможные параметры:

  • python – список зависимостей Python.

  • system – список системных зависимостей.

  • all_from_collections – исключить все зависимости Python и системы из одной или нескольких коллекций. Укажите список названий коллекций в этом параметре.

Для простого сопоставления названий необходимо указать название требования или коллекции для сопоставления. Все значения будут сравниваться без учета регистра.

Для расширенного сопоставления названий начните строку исключения с символа тильды (~), чтобы указать, что оставшаяся часть строки является регулярным выражением, которое будет использоваться для сопоставления названия требования или коллекции. Регулярное выражение не чувствительно к регистру.

Примечание

Регулярное выражение должно соответствовать полному названию требования или коллекции. Например, ~foo. не полностью соответствует названию foobar, а ~foo.+ – соответствует.

При обеих формах сопоставления строка исключения будет сравниваться с простым названием зависимости Python или системы. Например, если вам нужно исключить системное требование, которое отображается как foo [!platform:gentoo] внутри включенной коллекции, то ваша строка исключения должна быть foo. Чтобы исключить требование Python bar == 1.0.0, строка должна иметь значение bar.

Пример использования простого и расширенного сопоставления:

dependencies:
 exclude:
     python:
         - docker
     system:
         - python3-Cython
     all_from_collections:
         # Regular expression to exclude all from community collections
         - ~community\..+

В следующем примере используются имена файлов, содержащих различные зависимости:

dependencies:
 python: requirements.txt
 system: bindep.txt
 galaxy: requirements.yml
 ansible_core:
     package_pip: ansible-core==2.15.6
 ansible_runner:
     package_pip: ansible-runner==2.3.1
 python_interpreter:
     package_system: "python310"
     python_path: "/usr/bin/python3.10"

В этом примере используются встроенные значения:

dependencies:
 python:
   - pywinrm
 system:
   - iputils [platform:rpm]
 galaxy:
   collections:
     - name: community.windows
     - name: ansible.utils
       version: 2.10.1
 ansible_core:
     package_pip: ansible-core==2.15.6
 ansible_runner:
     package_pip: ansible-runner==2.3.1
 python_interpreter:
     package_system: "python310"
     python_path: "/usr/bin/python3.10"

Образ#

В разделе image указывается базовый образ, который будет использоваться для сборки контейнера.

Пример заполнения:

images:
  base_image:
    name: aa-cr.artifactory.astralinux.ru/aa-creator-ee:0.1.0

additional_build_files#

В разделе additional_build_files указываются файлы, которые необходимо добавить в каталог контекста сборки. Затем на них можно ссылаться или копировать с помощью additional_build_steps на любом этапе сборки.

Каждый элемент списка должен быть словарем, содержащим следующие (необязательные) ключи:

  • src – путь к исходному файлу или директории, который необходимо добавить в контекст сборки. Это может быть либо абсолютный путь (например, /home/user/.ansible.cfg), либо путь относительно файла среды исполнения. Относительные пути могут быть глобальным выражением, соответствующим одному или нескольким файлам (например, files/*.cfg).

  • dest – указывает путь к подкаталогу контекста сборки, который должен содержать исходный файл (например, files/configs). Этот каталог будет создан, если он не существует.

Пример заполнения:

additional_build_files:
 - src: files/ansible.cfg
   dest: configs

Дополнительные шаги сборки#

В секции additional_build_steps указываются команды для дополнительных шагов пользовательской сборки.

Команды prepend и append могут быть указаны в секции additional_build_steps. Они добавят в Containerfile команды, которые будут выполняться соответственно до или после выполнения основных шагов сборки.

Допускаются следующие варианты заполнения:

  • Многострочная запись:

    prepend_final: |
       RUN whoami
       RUN cat /etc/os-release
    
  • Список:

    append_final:
       - RUN echo
       - RUN ls -la /etc
    

Примеры создания образа среды исполнения#

Изучите использование Ansible Builder на примерах. Предварительно выполните следующие действия:

  1. Настройте доступ к Private Automation Hub.

  2. Создайте каталог проекта и сделайте его текущим, например:

    mkdir ee-build && cd ee-build
    

    Все упомянутые ниже файлы следует создавать в каталоге проекта, если только явно не указано иное.

Установка библиотек Python#

Для добавления библиотеки Python в образ выполните следующие действия:

  1. Создайте файл execution-environment.yml и в нем укажите параметры образа, в том числе ссылку на образ, используемый в качестве основы:

    ---
    version: 3
    images:
      base_image:
       name: registry.astralinux.ru/aa/aa-base-ee:0.6.2
    dependencies:
      python: requirements.txt
    
  2. Создайте файл requirements.txt и укажите в нем библиотеку Python, которую необходимо добавить в образ, например:

    yamllint
    
  3. Запустите команду сборки образа:

    ansible-builder build -t my-ee:0.1.0 -v 3
    

    Здесь:

    • my-ee – название образа;

    • 0.1.0 – версия образа.

Проверьте наличие нового образа с помощью команды:

ansible-navigator images

Добавление коллекции Ansible#

Чтобы добавить в образ коллекцию Ansible, выполните следующие действия:

  1. Создайте файл зависимостей Ansible requirements.yml, например:

    ---
    collections:
      - name: astra.nginx
        version: 1.8.2
    

    Здесь:

    • name – полное название коллекции, включая пространство имен;

    • version – версия коллекции.

  2. Загрузите коллекцию:

    ansible-navigator exec -- ansible-galaxy collection download -r requirements.yml
    

    В каталоге collections появится запрошенная коллекция в формате tar.gz и файл requirements.yml.

  3. Создайте файл execution-environment.yml для настройки Ansible Builder со следующим содержимым:

    ---
    version: 3
    
    images:
      base_image:
        name: registry.astralinux.ru/aa/aa-base-ee:0.6.2
    
    dependencies:
      galaxy: collections/requirements.yml
    
  4. Создайте контекст сборки:

    ansible-builder create -v 3
    
  5. Скопируйте коллекцию в контекст сборки, например:

    cp collections/astra-nginx-1.8.2.tar.gz context/_buid/
    
  6. Создайте новый образ:

    ansible-builder build -t my-ee:0.2.0 -v 3
    

Проверьте наличие нового образа с помощью команды:

ansible-navigator images

Добавление коллекции из приватного репозитория Git#

Доступ к приватному репозиторию Git можно получить разными способами. В данном примере рассматривается использование приватного ключа SSH.

Чтобы добавить коллекцию из приватного репозитория Git, на этапе сборки необходимо передать полномочия в контейнер. Для этого выполните следующие действия:

  1. В каталоге проекта разместите файл приватного ключа SSH id_rsa, позволяющий получить доступ к репозиторию.

    Примечание

    Приватный ключ не должен быть защищен паролем.

  2. В файле execution-environment.yml измените ссылку на файл зависимостей и добавьте строки, обеспечивающие передачу ключа в домашний каталог пользователя root контейнера:

    ---
    version: 3
    
    images:
      base_image:
        name: registry.astralinux.ru/aa/aa-base-ee:0.6.2
    
    dependencies:
      galaxy: requirements.yml
    
    additional_build_files:
      - src: id_rsa
        dest: ssh
    
    additional_build_steps:
      prepend_galaxy: |
        RUN mkdir /root/.ssh/
        RUN printf 'Host git.example.com\n\tIdentityFile /root/.ssh/id_rsa\nStrictHostKeyChecking no\n' > /root/.ssh/config
        COPY --chmod=0600 ./_build/ssh/id_rsa /root/.ssh/id_rsa
      append_galaxy: |
        RUN rm -rf /root/.ssh
    
  3. В файле requirements.yml укажите параметры источника коллекции, например:

    ---
    collections:
      - name: astra.nginx
        version: 1.8.2
    
  4. Создайте новый образ:

    ansible-builder build -t my-ee:0.3.0 -v 3
    

Проверьте наличие нового образа с помощью команды:

ansible-navigator images

Добавление коллекций из Private Automation Hub#

Чтобы добавить в образ среды исполнения коллекции, размещенные в Private Automation Hub, выполните следующие действия:

  1. Создайте токен для доступа к Private Automation Hub согласно инструкции.

  2. В каталоге проекта создайте подкаталог files, а в нем – файл ansible.cfg с настройками подключения к репозиториям Private Automation Hub, например:

    [galaxy]
    server_list = galaxy, validated
    
    [galaxy_server.galaxy]
    url = https://galaxy.ansible.com/
    
    [galaxy_server.validated]
    url = https://private-hub.example.com/api/galaxy/content/validated/
    

    Здесь указаны публично доступны репозиторий Ansible Galaxy и репозиторий validated, размещенный в Private Automation Hub.

  3. Заполните файл определения среды исполнения.

    ---
    version: 3
    
    dependencies:
      galaxy:
        collections:
          - name: astra.ald_pro
            version: 2.0.0
          - name: astra.cups
            version: 1.3.3
          - name: astra.rubackup
          - name: astra.rupost
    
    images:
      base_image:
        name: registry.astralinux.ru/aa/aa-base-ee:latest
    
    additional_build_files:
      - src: ansible.cfg
        dest: configs
    
    additional_build_steps:
      prepend_galaxy:
        - COPY _build/configs/ansible.cfg /etc/ansible/ansible.cfg
        - ARG ANSIBLE_GALAXY_SERVER_VALIDATED_TOKEN
    

    Список необходимых коллекций указан в параметре depdendencies.galaxy.collections.

    При сборке образа на основе приведенного выше файла определения среды исполнения Ansible Builder выполняет следующие действия:

    1. Копирует файл ansible.cfg из корневого каталога проекта в контекст сборки – каталог _build/configs/.

    2. Перед этапом Galaxy копирует файл ansible.cfg из каталога _build/configs/ в файловую систему образа по пути /etc/ansible/ansible.cfg.

    3. На этапе установки зависимостей Ansible вызывает утилиту ansible-galaxy, которая использует реестры, перечисленные в файле /etc/ansible/ansible.cfg. Для получения доступа к Private Automation Hub используется токен, заданный в переменной окружения ANSIBLE_GALAXY_SERVER_VALIDATED_TOKEN. Значение этой переменной импортируется в образ из хостовой системы.

      Название переменной окружения, в которой хранится токен для доступа к реестру, формируется по шаблону:

      ANSIBLE_GALAXY_SERVER_<NAME>_TOKEN
      

      Здесь <NAME> – набранное в верхнем регистре название сервера, указанное в ansible.cfg. Например, если бы серверы назывались published и testing_dev, соответствующие переменные окружения имели бы названия ANSIBLE_GALAXY_SERVER_PUBLISHED_TOKEN и ANSIBLE_GALAXY_SERVER_TESTING_DEV_TOKEN.

  4. Экспортируйте токен для доступа к Private Automation Hub в соответствующую переменную окружения:

    export ANSIBLE_GALAXY_SERVER_VALIDATED_TOKEN=<token>
    
  5. Запустите сборку образа:

    ansible-navigator builder build \
      -t my-ee:1.0.0 \
      --build-arg ANSIBLE_GALAXY_SERVER_VALIDATED_TOKEN