Ansible 主机清单配置文件

Ansible 系列:html

Ansible 主机配置清单文件

参考至官方文档,官方文档包含了清单文件的 YAML 写法node

在经过 Ansible 操做目标主机以前,你须要先在 Inventory(主机清单)中配置目标主机信息。python

默认状况下主机清单保存在系统的 /etc/ansible/hosts 文件中,你也能够经过命令行选项指定其它的清单文件 -i <path>nginx

主机清单配置默认格式为 INI,下面是一个主机清单配置例子:web

[web] 
www.abc.com1
192.168.0.2
复制代码

上述配置中方括号为组名,www.abc.com1 和 192.168.0.2 为被监控主机的域名或 IP。也能够是主机名,但此时须要指定主机 IP 环境变量 。redis

[web] 
node ansible_host=192.0.2.50
复制代码

默认采用密钥认证,若是没有密钥认证,那么你须要配置主机密码环境变量。shell

[web] 
www.abc.com1 ansible_user=root ansible_password=123456
复制代码

你也能够对指定组下的主机进行统一的环境变量配置:apache

[web] 
www.abc.com1 ansible_user=root ansible_password=123456 http_port=8080
192.168.0.2 ansible_user=root ansible_password=123451

[web:vars]
http_port=80
ssh_port=22
redis_port=6379
复制代码

若是主机名或 IP 是有序有规则的,你还能够采用数字或字符范围格式,而不是列出每一个主机名:tomcat

[webservers]
www[01:50].example.com

[databases]
db-[a:f].example.com
复制代码

组的继承

组还支持继承(嵌套),其格式为 组名+":children" 组成,以下:ruby

[shenzhen]
host1
host2
[guangzhou]
host3
host4
[guangdong:children]
shenzhen
guangzhou
[guangdong:vars]
tomcat=192.168.8.8
nginx=192.168.8.66
apache=192.168.8.77
zabbix=192.168.8.88
[china:children]
guangdong
beijing
shanghai
复制代码

上面我指定了深圳组有 host一、host2,广州组有host三、host4。广东组包含深圳和广州,同时为该组内的全部主机指定了四个环境变量。后又设定了一个中国组,包含广东、北京、上海。

默认组

全部主机都属于两个隐式的组:

  • **all:**包含每一个主机
  • **ungrouped:**除了 all 组以外没有其它组的主机

组织环境变量

环境变量除了写在主机清单文件中,还能够单独存储在单个文件中。

咱们能够在主机清单文件的同级目录中建立两个目录 "group_vars" 和 "host_vars",分别存储组变量与主机变量文件。

如咱们在主机清单文件中声明了组 test,此时在 group_vars 目录下建立一个名为 test 的文件(该文件为 YAML 格式),其内容以下:

tomcat: 192.168.8.8
复制代码

此时 test 组中的主机将会包含 tomcat 这个环境变量。

当 "group_vars" 或 "host_vars" 外部环境变量文件与主机清单文件中的环境变量冲突时,前者优先级更高。

特殊环境变量

Ansible 定义了一些固定的环境变量名,这些环境变量将会影响 Ansible 的行为。

ansible_connection #主机链接类型,这能够是任何 ansible 链接插件的名称,如 smart、ssh、paramiko、local
ansible_ssh_host # 将要链接的远程主机名.与你想要设定的主机的别名不一样的话,可经过此变量设置.
ansible_ssh_port # 链接端口号(默认22)
ansible_ssh_user # 链接主机时的用户名
ansible_ssh_pass # 用于验证主机的密码
ansible_ssh_private_key_file # ssh 使用的私钥文件.适用于有多个密钥,而你不想使用 SSH 代理的状况.
ansible_ssh_common_args # 此设置附加到 sftp,scp 和 ssh 的缺省命令行
ansible_sftp_extra_args # 此设置附加到默认 sftp 命令行
ansible_scp_extra_args # 此设置附加到默认 scp 命令行
ansible_ssh_extra_args # 此设置附加到默认 ssh 命令行
ansible_ssh_pipelining # 肯定是否使用 SSH 管道。 这能够覆盖 ansible.cfg 中得设置
ansible_shell_type # 目标系统的 shell 类型,默认状况下命令的执行使用 'sh' 语法,可设置为 'csh' 或 'fish'
ansible_python_interpreter # 目标主机的 python 路径,适用于的状况: 系统中有多个 Python, 或者命令路径不是"/usr/bin/python",好比 *BSD, 或者 /usr/bin/python
ansible_interpreter # 这里的""能够是 ruby、perl 或其余语言的解释器,做用和ansible_python_interpreter 相似
ansible_shell_executable # 这将设置 ansible 控制器将在目标机器上使用的 shell,覆盖 ansible.cfg 中的配置,默认为 /bin/sh
复制代码
相关文章
相关标签/搜索