Зарегистрируйтесь для доступа к 15+ бесплатным курсам по программированию с тренажером

Переменные в файле инвентаризации Основы автоматизации в Ansible

Переменные в Ansible можно устанавливать не только в плэйбуках и пользовательских файлах, но в inventory-файлах. Для того, чтобы установить переменную для конкретного хоста, достаточно после его имени написать название переменной и её значение:

[webservers]
web1.example.com root_dir=/var/tmp server_name=hexlet.io
web2.example.com root_dir=/var/tmp

Если же эта переменная относится к группе хостов, то её можно указать в отдельной секции, добавив к имени группы ключевое слово vars:

[webservers]
web1.example.com server_name=hexlet.io
web2.example.com

[appservers]
app1.example.com

[webservers:vars]
root_dir=/var/tmp

Если переменная относится ко всем хостам, то используется ключевое слово all:

[all:vars]
root_dir=/var/tmp

Это особенно полезно, если нужно поддерживать несколько сред развёртывания с разной конфигурацией. Таким способом можно указывать разные хосты, пароли и другие конфигурационные параметры.

Полный список всех серверов, групп и переменных можно посмотреть с помощью команды ansible-inventory с флагами --list или --graph:

ansible-inventory -i inventory.ini --list
{
    "_meta": {
        "hostvars": {
            "app1.example.com": {
                "root_dir": "/var/tmp"
            },
            "web1.example.com": {
                "root_dir": "/var/tmp",
                "server_name": "hexlet.io"
            },
            "web2.example.com": {
                "root_dir": "/var/tmp"
            }
        }
    },
    "all": {
        "children": [
            "appservers",
            "ungrouped",
            "webservers"
        ]
    },
    "appservers": {
        "hosts": [
            "app1.example.com"
        ]
    },
    "webservers": {
        "hosts": [
            "web1.example.com",
            "web2.example.com"
        ]
    }
}
ansible-inventory -i inventory.ini --graph
@all:
  |--@appservers:
  |  |--app1.example.com
  |--@ungrouped:
  |--@webservers:
  |  |--web1.example.com
  |  |--web2.example.com

Если параметров становится слишком много, и они не зависят от среды, то их можно вынести из inventory-файла. Для этого создаётся директория group_vars с файлами, соответствующими названиям групп. Эти файлы не имеют расширения, но по факту являются yml-файлами. Поэтому в отличие от ini-файла пары параметр=значение записываются в них через двоеточие, например, root_dir: /var/tmp.

Так же можно поступать с переменными, которые принадлежат конкретному хосту. Только директория с файлами, соответствующими названиям хостов, будет именоваться host_vars.


Самостоятельная работа

  1. Перенесите переменные из плейбука в файл group_vars/webservers/all.yml
  2. Создайте два файла с переменными хостов для каждого сервера: host_vars/<имя_сервера>/all.yml. Создайте в этих файлах по переменной server_name с разными значениями для разных серверов.
  3. Замените файл index.html на шаблон. Добавьте в него строчку с именем сервера.

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <meta http-equiv="X-UA-Compatible" content="IE=edge">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <title>Hello World!</title>
    </head>
    <body>
      <h1>Hello World!</h1>
      <h2>This is server {{ server_name }}!</h2>
    </body>
    </html>
    
  4. Выполните плейбук. Если всё выполнено успешно, каждый из серверов отображает разное имя сервера

  5. Залейте изменения на Github


Дополнительные материалы

  1. Организация переменных / Документация Ansible
  2. Порядок применения переменных / Документация Ansible

Аватары экспертов Хекслета

Остались вопросы? Задайте их в разделе «Обсуждение»

Вам ответят команда поддержки Хекслета или другие студенты.

Ошибки, сложный материал, вопросы >
Нашли опечатку или неточность?

Выделите текст, нажмите ctrl + enter и отправьте его нам. В течение нескольких дней мы исправим ошибку или улучшим формулировку.

Что-то не получается или материал кажется сложным?

Загляните в раздел «Обсуждение»:

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

Об обучении на Хекслете

Для полного доступа к курсу нужен базовый план

Базовый план откроет полный доступ ко всем курсам, упражнениям и урокам Хекслета, проектам и пожизненный доступ к теории пройденных уроков. Подписку можно отменить в любой момент.

Получить доступ
900
упражнений
2000+
часов теории
3200
тестов

Открыть доступ

Курсы программирования для новичков и опытных разработчиков. Начните обучение бесплатно.

  • 130 курсов, 2000+ часов теории
  • 900 практических заданий в браузере
  • 360 000 студентов
Даю согласие на обработку персональных данных, соглашаюсь с «Политикой конфиденциальности» и «Условиями оказания услуг»

Наши выпускники работают в компаниях:

Логотип компании Альфа Банк
Логотип компании Aviasales
Логотип компании Yandex
Логотип компании Tinkoff

Используйте Хекслет по максимуму!

  • Задавайте вопросы по уроку
  • Проверяйте знания в квизах
  • Проходите практику прямо в браузере
  • Отслеживайте свой прогресс

Зарегистрируйтесь или войдите в свой аккаунт

Даю согласие на обработку персональных данных, соглашаюсь с «Политикой конфиденциальности» и «Условиями оказания услуг»