ansible para criar vpc solicitando hosts

ansible para criar vpc solicitando hosts

Sou muito novo no ansible e, ao ler as coisas, o que estou fazendo deve funcionar. Eu tenho o seguinte arquivo chamadoaws.yml

---
- hosts: localhost
  connection: local
  gather_facts: no
  vars:
    aws_region: us-east-1
  tasks:
    - name: Main VPC
      ec2_vpc:
        state: present
        cidr_block: 10.5.0.0/16
        resource_tags: {"environment": "prod"}
        region: "{{ aws_region }}"
        dns_hostnames: no
        dns_support: yes
        instance_tenancy: default
        internet_gateway: yes
        subnets:
          - cidr: 10.5.151.96/27
            az:  "{{ aws_region }}a"
            resource_tags: {"Name": "private"}
          - cidr: 10.5.151.128/27
            az:  "{{ aws_region }}b"
            resource_tags: {"Name": "private"}
          - cidr: 10.5.151.160/27
            az:  "{{ aws_region }}c"
            resource_tags: {"Name": "private"}

Quando executo o ansible-playbook, recebo o seguinte

$ ansible-playbook aws.yml
ERROR: Unable to find an inventory file, specify one with -i ?

Pelo que entendi são os hosts: localhost deve substituir o uso de -i e como estou tentando criar um VPC aqui, não quero fazer ssh em máquinas para construí-lo.

Obrigado

Responder1

Você precisa apontar para um arquivo de inventário (mesmo que vazio), porque o playbook apenas diz a quais hosts a peça se aplica, mas não fornece os meios para definir tal lista, o inventário fornece. Felizmente, localhostestá disponível por padrão:

$ cat playbook.yml
---
- hosts: localhost
  connection: local
  gather_facts: no
  tasks:
    - shell: echo foo

$ ansible-playbook -i /dev/null playbook.yml
 [WARNING]: provided hosts list is empty, only localhost is available

PLAY [localhost] **************************************************************

TASK: [shell echo foo] ********************************************************
changed: [localhost]

PLAY RECAP ********************************************************************
localhost                  : ok=1    changed=1    unreachable=0    failed=0

informação relacionada