Я написал плейбук для создания контейнера внутри хост-машины. Моя идея заключается в создании нескольких контейнеров на хосты. Я пытаюсь использовать файл host.ini для разделения хост-машин как группы и каждого контейнера как хоста Ansible внутри группы. Знаете ли вы, как структурировать файл хоста, чтобы использовать переменную ansible_host для именования контейнеров в плейбуке, используемом для их создания?
мой хост-файл:
-----
[host.machine.1]
machine.1.container-1
machine.1.container-2
machine.1.container-3
[host.machine.2]
machine.2.container-1
machine.2.container-2
machine.2.container-3
[host.machine.3]
machine.3.container-1
machine.3.container-2
machine.3.container-3
мой функциональный план действий:
---
- name: Create container
hosts: host.machine.1:host.machine.2:host.machine.3
vars:
agent_name: "{{ container_name }}"
tasks:
- name: Docker pull
command: docker pull container.image:latest
- name: Docker volume
command: docker volume create agent_{{ container_name }}
- name: Docker run
command: docker run -d -it --privileged --name agent-{{ container_name }} -e AGENT_NAME="{{ container_name }}" --network network1 --cpus=8 --memory=32g --ipc=host -e TZ=CET docker-registry/container.image:latest
Спасибо
решение1
Создайте переменную, которая перечисляет контейнеры для каждого хоста.
host_vars/host1.yml
containers:
- name: agent1
image: docker-registry/container.image:latest
- name: agent2
image: docker-registry/container.image:latest
- name: agent3
image: docker-registry/container.image:latest
То же самое и для других хостов.
Затем в книге вы можетепройдемся по этому списку:
hosts: host1,host2,host3
tasks:
- name: Docker volume
command: "docker volume create agent_{{ item.name }}"
loop: {{ containers }}
- name: Docker run
command: "docker run -d -it --privileged --name agent-{{ item.name }} -e AGENT_NAME=\"{{ item.name }}\" --network network1 --cpus=8 --memory=32g --ipc=host -e TZ=CET {{ item.image }}"
loop: "{{ containers }}"
Или, используяправильные модули:
hosts: host1,host2,host3
tasks:
- name: Docker volume
docker_volume:
name: "agent_{{ item.name }}"
loop: {{ containers }}
- name: Docker run
docker_container:
name: "agent-{{ item.name }}"
image: "{{ item.image }}"
privileged: yes
volumes:
- "agent_{{ item.name }}"
loop: "{{ containers }}"