WedX - журнал о программировании и компьютерных науках

Бродячий Ansible и роли модуля

Я создаю прототип Ansible с помощью Vagrant и использую «vagrant Provision» для создания своего стека. Я определил роли для создания базовой системы, веб-сервера, сервера базы данных и сервера приложений. (Основная система будет состоять из ролей, которые потребуются для любого типа системы, например, для установки системных пакетов и пользователей).

Я хотел бы настроить Vagrant для выполнения всех ролей (чтобы установить все на одной виртуальной машине), но в производственной среде я мог бы захотеть установить только определенные роли на определенных машинах. Как лучше всего структурировать мою книгу и инвентарный файл, чтобы я мог разместить на одном сервере машину Vagrant и группу производственных машин с несколькими серверами?

Будет ли это включать в себя создание нескольких пьес? Один для Vagrant и один для каждой конфигурации? Если так, это может привести к большому дублированию кода.

Вот что у меня пока есть, но не работает ...

Вот полный проект: https://github.com/JoeJasinski/docker-ansible-web

Vagrantfile

VAGRANTFILE_API_VERSION = "2"

Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
  config.vm.box = "ubuntu/trusty64"
  config.vm.network "forwarded_port", guest: 80, host: 8080
  config.vm.provision :ansible do |ansible|
    ansible.playbook = "ansible/site.yml"
    ansible.verbose = "vvv"
    ansible.extra_vars = {}
    ansible.inventory_path = "ansible/inventory.ini"
    ansible.sudo = true
    ansible.groups = {
      "nginxServer" => ["nginxServer",],
      "djangoServer" => ["djangoServer",],
      "postgresServer" => ["postgresServer",]
   }
end

inventory.ini

[nginxServer]
127.0.0.1

[djangoServer]
127.0.0.1

[postgresServer]
127.0.0.1

site.yml

---
- name: Base states
  hosts: all
  vars:
    - update_apt_cache: yes
  vars_files:
    - env_vars/base.yml
  roles:
    - role: base
    - { role: users, tags: ['users'] }
    - { role: sites, tags: ['sites'] }

- name: Nginx Host
  hosts: nginxServer
  vars:
    - update_apt_cache: yes
  vars_files:
    - env_vars/base.yml
  roles:
    - { role: supervisor, tags: ['supervisor'] }
    - { role: nginx, tags: ['nginx'] }

- name: Django Host
  hosts: djangoServer
  vars:
    - update_apt_cache: yes
  vars_files:
    - env_vars/base.yml
  roles:
    - { role: supervisor, tags: ['supervisor'] }
    - { role: django, tags: ['django'] }

- name: Postgres Host
  hosts: postgresServer
  vars:
    - update_apt_cache: yes
  vars_files:
    - env_vars/base.yml
  roles:
    - { role: postgres, tags: ['postgres'],}
    - { role: postgis, tags: ['postgis'], }

Ответы:


1

Будет ли это включать в себя создание нескольких пьес? Один для Vagrant и один для каждой конфигурации? Если так, это может привести к большому дублированию кода.

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

- include: webserver.yml
- include: database.yml
- include: application.yml

Другая идея - просто иметь условные роли. Если я правильно вас понял, у вас есть группы nginxServer, djangoServer и postgresServer, и ваша тестовая виртуальная машина входит во все 3 группы, а ваша производственная только хозяева входят в одну или две группы. Если это верно, вы можете просто добавить условия к ролям.

Например:

  roles:
    - role: supervisor
      tags: supervisor
      when: "nginxServer" in group_names

    - role: nginx
      tags: nginx
      when: "nginxServer" in group_names

Однако время выполнения будет больше, поскольку Ansible по-прежнему будет обрабатывать все роли. Фактически условия передаются каждой задаче внутри ролей, поэтому тогда у вас будет много пропущенных задач.

02.03.2016
  • Спасибо за информацию здесь. Операторы include кажутся довольно полезными и приятными для возможности условно добавлять подобные группы. 05.03.2016

  • 2

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

    Например, если у вас есть установка с одним веб-сервером, одним сервером приложений и одним сервером базы данных, то ваш инвентарь будет выглядеть следующим образом:

    [nginxServer]
    web.example.org
    
    [djangoServer]
    app.example.org
    
    [postgresServer]
    database.example.org
    

    Или, если вы хотите только отделить базу данных от объединенного окна веб-приложения / приложения, у вас будет что-то вроде:

    [nginxServer]
    app.example.org
    
    [djangoServer]
    app.example.org
    
    [postgresServer]
    database.example.org
    

    Что запустит ваш nginx, и приложение будет играть против того же app.example.org хоста.

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

    [nginxServer]
    web-1.example.org
    web-2.example.org
    
    [djangoServer]
    app-1.example.org
    app-2.example.org
    app-3.example.org
    app-4.example.org
    
    [postgresServer:children]
    postgresMaster
    postgresSlave
    
    [postgresMaster]
    database-1.example.org
    
    [postgresSlave]
    database-2.example.org
    

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

    Если вы хотите настроить таргетинг только на отдельные группы хостов (например, nginxServers), вы можете сделать это, просто используя _ 6_ со своим исходным учебником или вы можете написать более конкретные учебники, которые нацелена только на эту группу хостов для роли, а затем создайте сценарий верхнего уровня, который запускает все другие сценарии, когда вы хотите подготовить все:

    site.yml

    - include: webserver.yml
    - include: database.yml
    - include: application.yml
    

    webserver.yml

    - name: Nginx Host
      hosts: nginxServer
      vars:
        - update_apt_cache: yes
      vars_files:
        - env_vars/base.yml
      roles:
        - { role: supervisor, tags: ['supervisor'] }
        - { role: nginx, tags: ['nginx'] }
    

    Что касается базовой игры, я бы предпочел сделать эту роль зависимостью, поскольку на всех других ваших серверах базовая роль всегда должна запускаться против них, независимо от того, как эта роль называется. Вы можете сделать это, создав папку meta для каждой из трех основных ролей и включив туда main.yml файл со следующим содержимым:

    dependencies:
        -   role: base
        - { role: users, tags: ['users'] }
        - { role: sites, tags: ['sites'] }
    
    02.03.2016
  • Спасибо, что поделились этим. Я закончил тем, что добавил кучу зависимостей по вашему предложению. Мне нужно еще провести рефакторинг, но это помогло мне встать на правильный путь. 05.03.2016
  • Новые материалы

    Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что это выглядит сложно…
    Просто начните и учитесь самостоятельно Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что он кажется мне сложным, и я бросил его. Это в основном инструмент..

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

    Объяснение документов 02: BERT
    BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

    Как проанализировать работу вашего классификатора?
    Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

    Работа с цепями Маркова, часть 4 (Машинное обучение)
    Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

    Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
    Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..

    Использование машинного обучения и Python для классификации 1000 сезонов новичков MLB Hitter
    Чему может научиться машина, глядя на сезоны новичков 1000 игроков MLB? Это то, что исследует это приложение. В этом процессе мы будем использовать неконтролируемое обучение, чтобы..


    Для любых предложений по сайту: [email protected]