2016-02-05 21 views
8

Tentativo di registrare un'istanza ec2 in AWS con il modulo ec2_ami di Ansible e l'utilizzo della data/ora corrente come versione (in futuro ci saranno molte AMI).'ansible_date_time' non è definito

Questo è quello che ho:

- name: Create new AMI 
    hosts: localhost 
    connection: local 
    gather_facts: false 
    vars: 
    tasks: 
    - include_vars: ami_vars.yml 
    - debug: var=ansible_date_time 
    - name: Register ec2 instance as AMI 
     ec2_ami: aws_access_key={{ ec2_access_key }} 
       aws_secret_key={{ ec2_secret_key }} 
       instance_id={{ temp_instance.instance_ids[0] }} 
       region={{ region }} 
       wait=yes 
       name={{ ami_name }} 
     with_items: temp_instance 
     register: new_ami 

Da ami_vars.yml:

ami_version: "{{ ansible_date_time.iso8601 }}" 
ami_name: ami_test_{{ ami_version }} 

Quando eseguo la piena playbook, ricevo questo messaggio di errore:

fatal: [localhost]: FAILED! => {"failed": true, "msg": "ERROR! ERROR! ERROR! 'ansible_date_time' is undefined"} 

Tuttavia , quando si esegue il comando di debug separatamente, da un playbook separato, funziona perfettamente:

- name: Test date-time lookup 
    hosts: localhost 
    connection: local 
    tasks: 
    - include_vars: ami_vars.yml 
    - debug: msg="ami version is {{ ami_version }}" 
    - debug: msg="ami name is {{ ami_name }}" 

Risultato:

TASK [debug] ******************************************************************* 
ok: [localhost] => { 
    "msg": "ami version is 2016-02-05T19:32:24Z" 
} 

TASK [debug] ******************************************************************* 
ok: [localhost] => { 
    "msg": "ami name is ami_test_2016-02-05T19:32:24Z" 
} 

Qualsiasi idea di cosa sta succedendo?

risposta

13

Inserisci questa:

gather_facts: false 

ansible_date_time fa parte dei fatti e non si stanno raccogliendo esso.

+0

Perfetto, grazie! Ora ricevo un errore diverso ma questo è praticamente solo problemi di formattazione lol. –