Ansible2:主机清单

Ansible 通过读取默认的主机清单配置/etc/ansible/hosts,可以同时连接到多个远程主机上执行任务, 默认路径可以通过修改 ansible.cfg 的 hostfile 参数指定路径。

一、Hosts and Groups(主机与组)

对于/etc/ansible/hosts最简单的定义格式像下面:

1、简单的主机和组

    mail.yanruogu.com    [webservers]    web1.yanruogu.com    web2.yanruogu.com     [dbservers]    db1.yanruogu.com    db2.yanruogu.com

a、中括号中的名字代表组名,可以根据自己的需求将庞大的主机分成具有标识的组,如上面分了两个组webservers和dbservers组;

b、主机(hosts)部分可以使用域名、主机名、IP地址表示;当然使用前两者时,也需要主机能反解析到相应的IP地址,一般此类配置中多使用IP地址;

2、端口与别名

如果某些主机的SSH运行在自定义的端口上,ansible使用Paramiko进行ssh连接时,不会使用你SSH配置文件中列出的端口,但是如果修改ansible使用openssh进行ssh连接时将会使用:

    192.168.1.1:3091

假如你想要为某些静态IP设置一些别名,可以这样做:

    web1 ansible_ssh_port = 3333 ansible_ssh_host = 192.168.1.2

上面的 web1别名就指代了IP为192.168.1.2,ssh连接端口为3333的主机。

3、指定主机范围

    [webservers]    www[01:50].yanruogu.com    [databases]    db-[a:f].yanruogu.com

上面指定了从web1到web50,webservers组共计50台主机;databases组有db-a到db-f共6台主机。

4、使用主机变量

以下是Hosts部分中经常用到的变量部分:

ansible_ssh_host     #用于指定被管理的主机的真实IPansible_ssh_port     #用于指定连接到被管理主机的ssh端口号,默认是22ansible_ssh_user     #ssh连接时默认使用的用户名ansible_ssh_pass     #ssh连接时的密码ansible_sudo_pass     #使用sudo连接用户时的密码ansible_sudo_exec     #如果sudo命令不在默认路径,需要指定sudo命令路径ansible_ssh_private_key_file     #秘钥文件路径,秘钥文件如果不想使用ssh-agent管理时可以使用此选项ansible_shell_type     #目标系统的shell的类型,默认shansible_connection     #SSH 连接的类型: local , ssh , paramiko,在 ansible 1.2 之前默认是 paramiko ,后来智能选择,优先使用基于 ControlPersist 的 ssh (支持的前提)ansible_python_interpreter     #用来指定python解释器的路径,默认为/usr/bin/python 同样可以指定ruby 、perl 的路径ansible_*_interpreter     #其他解释器路径,用法与ansible_python_interpreter类似,这里"*"可以是ruby或才perl等其他语言

示例如下:

[test]192.168.1.1 ansible_ssh_user=root ansible_ssh_pass=‘[email protected]‘192.168.1.2 ansible_ssh_user=breeze ansible_ssh_pass=‘123456‘192.168.1.3 ansible_ssh_user=bernie ansible_ssh_port=3055 ansible_ssh_pass=‘456789‘

上面的示例中指定了三台主机,三台主机的用密码分别是[email protected]、123456、45789,指定的ssh连接的用户名分别为root、breeze、bernie,ssh 端口分别为22、22、3055 ,这样在ansible命令执行的时候就不用再指令用户和密码等了。

5、组内变量

变量也可以通过组名,应用到组内的所有成员:

    [test]    host1    host2    [test:vars]    ntp_server=192.168.1.10    proxy=192.168.1.20

上面test组中包含两台主机,通过对test组指定vars变更,相应的host1和host2相当于相应的指定了ntp_server和proxy变量参数值 。

6、组的包含与组内变量

    [wuhan]    web1    web2    [suizhou]    web4    web3    [hubei:children]    wuhan    suizhou    [hubei:vars]    ntp_server=192.168.1.10    zabbix_server=192.168.1.10    [china:children]    hubei    hunan

上面的示例中,指定了武汉组有web1、web2;随州组有web3、web4主机;又指定了一个湖北组,同时包含武汉和随州;同时为该组内的所有主机指定了2个vars变量。设定了一个组中国组,包含湖北、湖南。

注:vars变量在ansible ad-hoc部分中基本用不到,主要用在ansible-playbook中。

二、Patterns(主机与组正则匹配部分)

把Patterns 直接理解为正则实际是不完全准确的,正常的理解为patterns意味着在ansible中管理哪些主机,也可以理解为,要与哪台主机进行通信。在探讨这个问题之前我们先看下ansible的用法:

ansible <pattern_goes_here> -m <module_name> -a <arguments>

直接上一个示例:

ansible webservers -m service -a "name=httpd state=restarted"

这里是对webservers 组或主机重启httpd服务 ,其中webservers 就是Pattern部分。而之所以上面说Pattern(模式)可以理解为正则,主要针对下面经常用到的用法而言的。

1、表示所有的主机可以使用all 或 *

2、通配符与逻辑或

利用通配符还可以指定一组具有规则特征的主机或主机名,冒号表示or---逻辑或

    web1.yanruogu.com    web1.yanruogu.com:web2.yanruogu.com    192.168.1.1    192.168.1.*

当然,这里的*通配符也可以用在前面,如:

    *.yanruogu.com    *.com    
    webservers1[0]     #表示匹配 webservers1 组的第 1 个主机    webservers1[0:25]  #表示匹配 webservers1 组的第 1 个到第 25 个主机(官网文档是":"表示范围,测试发现应该使用"-",注意不要和匹配多个主机组混淆)

上面的用法,在多个组之间同样适用 ,如:

    webservers    webservers:dbservers  #表示两个组中所有的主机

3、逻辑非与逻辑and

非的表达式,如,目标主机必须在组webservers但不在phoenix组中

    webserver:!phoenix

交集的表达式,如,目标主机必须即在组webservers中又在组staging中

    webservers:&staging

一个更复杂的示例:

    webserver:dbservers:&staging:!phoenix

上面这个复杂的表达式最后表示的目标主机必须满足:在webservers或者dbservers组中,必须还存在于staging组中,但是不在phoenix组中 。

4、混合高级用法

    *.yanruogu.com:*.org

还可以在开头的地方使用”~”,用来表示这是一个正则表达式:

    ~(web|db).*\.yanruogu\.com

给两个ansible-playbook中具体可能用的用法:

a、在ansible-palybook命令中,你也可以使用变量来组成这样的表达式,但是你必须使用“-e”的选项来指定这个表达式(通常我们不这样用):

    ansible-palybook -e webservers:!{{excluded}}:&{{required}}

b、在ansible和ansible-playbook中,还可以通过一个参数”--limit”来明确指定排除某些主机或组:

    ansible-playbook site.yml --limit datacenter2
c、从Ansible1.2开始,如果想排除一个文件中的主机可以使用"@":
    ansible-playbook site.yml --limit @retry_hosts.txt
时间: 2024-08-06 11:34:20

Ansible2:主机清单的相关文章

Ansible2:主机清单【转】

Ansible 通过读取默认的主机清单配置/etc/ansible/hosts,可以同时连接到多个远程主机上执行任务, 默认路径可以通过修改 ansible.cfg 的 hostfile 参数指定路径. 一.Hosts and Groups(主机与组) 对于/etc/ansible/hosts最简单的定义格式像下面: 1.简单的主机和组    mail.yanruogu.com    [webservers]    web1.yanruogu.com    web2.yanruogu.com 

自动化运维工具Ansible实战(二)主机清单的管理

Ansible安装好之后的主机清单配置文件有如下两种:1.yum安装,配置文件默认路径为:/etc/ansible/hosts2.源码包安装,主机清单配置文件路径需要从软件包里面拷贝,如下: [[email protected] ~]# mkdir /etc/ansible --创建ansible目录 [[email protected] ~]# cp /usr/src/ansible-2.5.0/examples/hosts /etc/ansible/ --拷贝文件(已拷贝忽略就好了) Ans

Ansible 五(inventory文件 主机清单)

Ansible 五(inventory文件  主机清单) Ansible 可同时操作属于一个组的多台主机,组和主机之间的关系通过 inventory 文件配置. 默认的文件路径为 /etc/ansible/hosts 除默认文件外,你还可以同时使用多个 inventory 文件(后面会讲到),也可以从动态源,或云上拉取 inventory 配置信息.详见 动态Inventory                   http://www.ansible.com.cn/docs/intro_dyna

Ansible---Inventory(主机清单)与YAML文件

Inventory主机清单 ansible默认的主机清单是/etc/ansible/hosts文件 主机清单可以手动设置,也可以通过Dynamic Inventory动态生成 一般主机名使用FQDN vim /etc/ansible/hosts [webserver] #方括号设置组名 www1.example.org #定义被监控主机,这边可以是主机名也可以是IP地址,主机名需要修改/etc/hosts文件 www2.example.org:2222 #冒号后定义远程连接端口,默认是ssh的2

剑客Ansible拔剑--YAML语言与Inventory主机清单

YAML介绍 YAML是一种用来表达资源序列的格式,由于参考了其他多语种,所以具有很高的可读性.YAML是YAML Ain't a Markup Language的缩写,即YAML不是XML.不过在研发这种语言是,YAML的意思其实是YAML Another Markup Language(仍是一种标记语言).其特性如下: (1).具有很好的可读性,易于实现: (2).表达能力强,扩展性好: (3).和脚本语言的交互性较好: (4).有一个一致的信息模型: (5).可以基于流来处理 1.YAML

Ansible之YAML,Inventory(主机清单)介绍

YAML介绍 YAML是一种用来表达资料序列的格式,由于参考了其他多种语言,所以具有很高的可读性.YAML与XML,HTML一样都属于标记性语言,是用来写配置文件的语言,非常简洁和强大. 其特性如下: (1)具有很好的可读性,易于实现(2)表达能力强,扩展性好(3)和脚本语言的交互性好(4)有一个一致的信息模型(5)可以基于流来处理更多关于YAML的内容可以参考http://www.yaml.org YAML语法YAML语法和其他语言类似,也可以表达散列表.标量等数据结构. (1)结构通过空格来

ansible认识主机清单文件

一.Ansible主机清单文件:Ansible可同时操作属于一个组的多台主机,组和主机之间的关系通过inventory文件配置. 默认的文件路径为/etc/ansible/hosts 1.对单个主机进行操作: ansible192.168.154.160 -m shell -a "ip a" 解释:192.168.154.160为被管理主机,-m shell:调用shell模块,进行查询被管理主机的ip 2.对被管理的主机组进行操作: ansible host -mshell -a &

细说Ansible主机清单inventory

Ansible是一个系列文章,我会尽量以通俗易懂.诙谐幽默的总结方式给大家呈现这些枯燥的知识点,让学习变的有趣一些. Ansible系列博文直达链接:Ansible入门系列 前言 关于Ansible是什么,我在之前的文章中没有说:当然了,我这里也不会说.当你看到我写的这篇文章时,我想你已经知道了Ansible是什么了,如果您还不知道什么是Ansible是什么,那我的建议是先去百度一下,知道了Ansible是什么了,知道了Ansible能干什么了以后,再回过头来继续阅读我这里的总结. 在Ansib

ansible深入理解和操作——02(主机清单,yml语法,playbook详解+操作)

本章内容:一.inventory主机清单二.yml语法三.playbook详解+操作 inventory主机清单 ansible默认的主机清单是/etc/ansible/hosts文件 主机清单可以手动设置,也可以通过Dynamic Inventory动态生成 一般主机名使用FQDN vi /etc/ansible/hosts [webserver] #方括号设置组名 www1.example.org #定义被监控主机,这边可以是主机名也可以是IP地址,主机名需要修改/etc/hosts文件 w