{{ hostvars[partner]['ansible_eth0']['ipv4']['address'] }} << doesn't work
"{'msg': "AnsibleUndefinedVariable: One or more undefined variables:
'partner' is undefined", 'failed': True}"
in inventory/host_vars/server1.domain there is 'partner: server2.domain'
On Tuesday, November 4, 2014 6:08:23 AM UTC-8, James Martin wrote:
>
> If you wanted to get the ip address of the first node in the
> production-cluster, you could do something like this. Think of the group
> as a list and 0 being the first element in the list.
>
> "{{
> hostvars[groups['production-cluster'][0]]['ansible_eth0']['ipv4']['address']
> }}"
>
> as far as your second example goes, you have some syntax errors in
> defining your variable. You don't need to encapsulate "partner" in curly
> brackets or quotes. The following should work:
>
>
> {{ hostvars[partner]['ansible_eth0']['ipv4']['address'] }}
>
>
> - James
>
>
>
>
> On Tuesday, November 4, 2014 6:59:16 AM UTC-5, Barry Morrison wrote:
>>
>> I have a pair of servers (server1.<environment>.domain,
>> server2.<environment>.domain) in two environments (staging and production).
>> Server1 is primary, server2 is secondary.
>>
>> When I originally built the playbook, I had aliases in the inventory file
>>
>> [staging-cluster]
>> primary server1.staging.domain
>> secondary server2.staging.domain
>>
>> And I'd target the IP of the other host with {{
>> hostvars['primary']['ansible_eth0']['ipv4']['address'] }} to get the of the
>> "other" host. This worked fine, until I needed the playbook to target
>> another set of hosts in production:
>>
>> [production-cluster]
>> primary server1.prod.domain
>> secondary server2.prod.domain
>>
>> The problem with the above, aliases are global and you can't have more
>> than one in an inventory. So...this breaks the above lookup {{
>> hostvars['secondary']['ansible_eth0']['ipv4']['address'] }}
>>
>> As much as I disliked the idea, I then thought to leverage
>> hostvars/serverX.environment.domain with a var like:
>>
>> primary: true
>> partner: server2.environment.domain
>>
>> The above var would exist on server1 since it is the primary and it's
>> partner is server2
>>
>> The problem with the above is, I can't expand {{ partner }} in the above
>> fact (may not have explained that properly, I can't do this:
>>
>> {{ hostvars['{{ partner }}']['ansible_eth0']['ipv4']['address'] }} or
>> this {{ hostavars[{{partner}}]['ansible_eth0']['ipv4']['address'] }}
>>
>> Anyone have any ideas on how I can manage a primary/secondary
>> role/membership in a cluster? Actually defining if the host is
>> primary/secondary is the easy part...but defining it's partner and getting
>> facts from its partner, I'm not certain of.
>>
>> Thanks!!
>>
>
--
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/540d439d-c6e5-47d7-b4b4-0a68c9bf0ec6%40googlegroups.com.
For more options, visit https://groups.google.com/d/optout.