Okay, so in the interest of moving to exact_count I switched from:
- name: Set up a new host instance on EC2
> ec2: >
> region="{{ ec2vars.region }}"
> zone="{{ ec2vars.zone }}"
> id="{{ serverPod + '_' + type }}"
> ec2_access_key="{{ ec2vars.ec2_access_key }}"
> ec2_secret_key="{{ ec2vars.ec2_secret_key }}"
> key_name="{{ ec2vars.key_name }}"
> instance_type="{{ ec2vars.instance_type }}"
> image="{{ ec2vars.image }}"
> group="{{ ec2vars.group }}"
> wait="{{ wait }}"
> wait_timeout=600
> user_data="{{ type }}"
> instance_tags='{"ec2serverPod":"{{ serverPod }}", "ec2type":"{{ type
> }}", "ec2serverPod_and_ec2type":"{{ serverPod }}_{{ type }}",
> "provisioned":"False", "Name":"{{ virtualhostFullName }}_{{ type }}"}'
> count="{{ count }}"
> vpc_subnet_id="{{ ec2vars.vpc_subnet_id }}"
> register: ec2
>
to:
- name: Set up a new host instance on EC2
> ec2: >
> region="{{ ec2vars.region }}"
> zone="{{ ec2vars.zone }}"
> ec2_access_key="{{ ec2vars.ec2_access_key }}"
> ec2_secret_key="{{ ec2vars.ec2_secret_key }}"
> key_name="{{ ec2vars.key_name }}"
> instance_type="{{ ec2vars.instance_type }}"
> image="{{ ec2vars.image }}"
> group="{{ ec2vars.group }}"
> wait="{{ wait }}"
> wait_timeout=600
> user_data="{{ type }}"
> instance_tags='{"ec2serverPod":"{{ serverPod }}", "ec2type":"{{ type
> }}", "ec2serverPod_and_ec2type":"{{ serverPod }}_{{ type }}",
> "provisioned":"False", "Name":"{{ virtualhostFullName }}_{{ type }}"}'
> exact_count="{{ count }}"
> count_tag="ec2serverPod_and_ec2type":"{{ serverPod }}_{{ type }}"
> vpc_subnet_id="{{ ec2vars.vpc_subnet_id }}"
> register: ec2
>
but I seem to have lost idempotence because I get new instances every time
it runs. I've since reformatted it to drop the quoted block and make it
look more like the docs but there was no improvement:
- name: Set up a new host instance on EC2
> local_action:
> module: ec2
> region: "{{ ec2vars.region }}"
> zone: "{{ ec2vars.zone }}"
> ec2_access_key: "{{ ec2vars.ec2_access_key }}"
> ec2_secret_key: "{{ ec2vars.ec2_secret_key }}"
> key_name: "{{ ec2vars.key_name }}"
> instance_type: "{{ ec2vars.instance_type }}"
> image: "{{ ec2vars.image }}"
> group: "{{ ec2vars.group }}"
> wait: "{{ wait }}"
> wait_timeout: 600
> user_data: "{{ type }}"
> instance_tags: '{"ec2serverPod":"{{ serverPod }}", "ec2type":"{{ type
> }}", "ec2serverPod_and_ec2type":"{{ serverPod }}_{{ type }}",
> "provisioned":"False", "Name":"{{ virtualhostFullName }}_{{ type }}"}'
> exact_count: "{{ count }}"
> count_tag: ec2serverPod_and_ec2type:"{{ serverPod }}_{{ type }}"
> vpc_subnet_id: "{{ ec2vars.vpc_subnet_id }}"
> register: ec2
>
Anyone see anything obvious with that last example? Do I have to list all
of the instance's tags in count_tag?
Thank you,
Mark
On Friday, March 7, 2014 8:26:58 PM UTC-6, Michael DeHaan wrote:
>
> You can see links to the documentation for the ID here:
>
> http://docs.ansible.com/ec2_module.html
>
> However, a better way to do it is to use the "exact_count" parameter and
> specify a tag.
>
> We should likely mark the id field in the documentation as legacy and
> non-preferred.
>
>
>
>
> On Fri, Mar 7, 2014 at 6:39 PM, Mark Casey <[email protected]<javascript:>
> > wrote:
>
>> Hello,
>>
>> When creating ec2 instances we have the "id" field for idempotency. I was
>> wondering how long previously-used ids linger for and, if they auto-prune,
>> whether they can be removed early/manually.
>>
>> Thank you,
>> Mark
>>
>> --
>> You received this message because you are subscribed to the Google Groups
>> "Ansible Project" group.
>> To unsubscribe from this group and stop receiving emails from it, send an
>> email to [email protected] <javascript:>.
>> To post to this group, send email to [email protected]<javascript:>
>> .
>> To view this discussion on the web visit
>> https://groups.google.com/d/msgid/ansible-project/c4289ff8-74fb-4b7b-8cfb-84d9516b9b35%40googlegroups.com<https://groups.google.com/d/msgid/ansible-project/c4289ff8-74fb-4b7b-8cfb-84d9516b9b35%40googlegroups.com?utm_medium=email&utm_source=footer>
>> .
>> For more options, visit https://groups.google.com/d/optout.
>>
>
>
--
You received this message because you are subscribed to the Google Groups
"Ansible Project" group.
To unsubscribe from this group and stop receiving emails from it, send an email
to [email protected].
To post to this group, send email to [email protected].
To view this discussion on the web visit
https://groups.google.com/d/msgid/ansible-project/13ec338a-eb64-46db-9262-aa0b7da1871a%40googlegroups.com.
For more options, visit https://groups.google.com/d/optout.