2016-04-07 16:22:36 -04:00
# This is the default ansible 'hosts' file.
#
# It should live in /etc/ansible/hosts
#
# - Comments begin with the '#' character
# - Blank lines are ignored
2017-10-20 10:48:06 +05:30
# - Top level entries are assumed to be groups, start with 'all' to have a full hierarchy
2016-04-07 16:22:36 -04:00
# - Hosts must be specified in a group's hosts:
# and they must be a key (: terminated)
# - groups can have children, hosts and vars keys
2018-11-29 14:22:48 -06:00
# - groups are unique and global - if you define a group in multiple locations, Ansible aggregates all the data to the global name.
# - If you define a group as a child of 2 different groups, it will be the child of both, any hosts and variables assigned will not be dependent on the parents, they will all be associated with the group.
2017-10-20 10:48:06 +05:30
# - Anything defined under a host is assumed to be a var
# - You can enter hostnames or IP addresses
# - A hostname/IP can be a member of multiple groups
2017-03-08 14:51:38 -05:00
2017-10-20 10:48:06 +05:30
# Ex 1: Ungrouped hosts, put them in 'all' or 'ungrouped' group
2017-03-08 14:51:38 -05:00
##all:
2016-04-07 16:22:36 -04:00
## hosts:
## green.example.com:
## ansible_ssh_host: 191.168.100.32
2017-05-11 18:01:20 -04:00
## anyvariable: value
2016-04-07 16:22:36 -04:00
## blue.example.com:
## 192.168.100.1:
## 192.168.100.10:
# Ex 2: A collection of hosts belonging to the 'webservers' group
2017-03-08 14:51:38 -05:00
## children:
## webservers:
## hosts:
## alpha.example.org:
## beta.example.org:
## 192.168.1.100:
## 192.168.1.110:
2016-04-07 16:22:36 -04:00
# Ex 3: You can create hosts using ranges and add children groups and vars to a group
2018-11-29 14:22:48 -06:00
# The child group can define anything you would normally add to a group.
# webservers is added as a child group of testing. gamma.example.org is added
# to the existing webservers group. All references to webservers will
# get alpha.example.org, beta.example.org, gamma.example.org, 192.168.1.100
# and 192.168.1.110. References to testing will get all of those hosts plus
# any host matching www[001:006].example.com
2016-04-07 16:22:36 -04:00
2017-03-08 14:51:38 -05:00
## testing:
## hosts:
## www[001:006].example.com:
## vars:
## testing1: value1
## children:
## webservers:
## hosts:
2018-11-29 14:22:48 -06:00
## gamma.example.org:
2017-03-08 14:51:38 -05:00
# Ex 4: all vars
2017-06-12 12:25:19 +05:30
# keeping within 'all' group you can define common 'all' vars here with lowest precedence
2017-03-08 14:51:38 -05:00
2016-04-07 16:22:36 -04:00
## vars:
2017-03-08 14:51:38 -05:00
## commontoall: thisvar