欢迎访问linux宝典,请记住本站唯一域名:www.linuxbaodian.com

ansible系列3 Inventory与Patterns

来源:原创    更新时间:2018-09-26 19:46:28    编辑:管理员    浏览:1659

Ansible的Inventory文件,可以理解为saltstack中的salt-key中的所有minion的列表以及用户自定义的nodegroup的概念,默认情况下这个文件是/etc/ansible/hosts ,后面还会讲到Dynamic Inventory,本节主要讲静态主机群部分。Patterns(模式)部分我们可以理解为正则表达式,通过Patterns我们可以匹配Inventory分组中的部分主机。


一、Hosts and Groups(主机与组)

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


1、简单的主机和组

[root@m01 ~]# cat /etc/ansible/hosts
all:
  children:
    web:
      hosts:
        172.16.1.7:
        172.16.1.8:
        172.16.1.9:
    rsync:
      hosts:
        172.16.1.41:
    nfs:
      hosts:
        172.16.1.31:
    mysql:
      hosts:
        172.16.1.51:

另外一种定义方法

[root@m01 ~]# cat /etc/ansible/hosts
[web]
172.16.1.7
172.16.1.8
172.16.1.9
[rsync]
172.16.1.41
[nfs]
172.16.1.31
[mysql]
172.16.1.51

a、中括号中的名字代表组名,你可以根据你自己的需求将庞大的主机分成具有标识的组,如上面我分了四个组web、rsync、nfs和mysql组;


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


2、端口与别名


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

192.168.0.10:5309

假如你想要为某些静态IP设置一些别名,类似于SaltStack中minion配置文件中id的参数配置。你可以这样做:

jumper ansible_ssh_port = 5555 ansible_ssh_host = 192.168.1.50

上面的 jumper 别名就指代了IP为192.168.1.50,ssh连接端口为5555的主机。


3、指定主机范围


[web]
www[01:50].linuxbaodian.com
[databases]
db-[a:f].ct99.cn

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


4、使用主机变量


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


ansible_ssh_host # 要连接的主机名
ansible_ssh_port # 端口号默认是22
ansible_ssh_user # ssh连接时默认使用的用户名
ansible_ssh_pass # ssh连接时的密码
ansible_sudo_pass # 使用sudo连接用户是的密码
ansible_ssh_private_key_file # 秘钥文件如果不想使用ssh-agent管理时可以使用此选项
ansible_shell_type # shell的类型默认sh
ansible_connection # SSH 连接的类型: local , ssh , paramiko在 ansible 1.2 之前默认是 paramiko ,后来智能选择,优先使用基于 ControlPersist 的 ssh (支持的前提)
ansible_python _ interpreter #用来指定 python 解释器的路径,同样可以指定ruby 、perl 的路径

示例如下:


[test]
.212.52.252 ansible_ssh_user=root ansible_ssh_pass='linuxbaodian.com'
.212.52.14 ansible_ssh_user=test1 ansible_ssh_pass='ct99.cn'
.212.52.16 ansible_ssh_user=test2 ansible_ssh_port=7788 ansible_ssh_pass='123456'

上面的示例中指定了三台主机,三台主机的用密码分别是linuxbaodian.com、ct99.cn、123456,指定的ssh连接的用户名分别为root、test1、test2,ssh 端口分别为22、22、7788 ,这样在ansible命令执行的时候就不用再指令用户和密码等了,执行结果如下:


[root@linuxbaodian.com ~]# ansible test -a 'uptime'
.212.52.252 | success | rc=0 >>
:34am  up 23 days 10:57,  2 users,  load average: 0.42, 0.39, 0.41
.212.52.16 | success | rc=0 >>
:41am  up 331 days  8:33,  2 users,  load average: 0.00, 0.01, 0.05
.212.52.14 | success | rc=0 >>
:40am  up 331 days  7:55,  2 users,  load average: 0.09, 0.03, 0.05

5、组内变量


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

[test]
host1
host2
[test:vars]
ntp_server=ntp.linuxbaodian.com
proxy=proxy.linuxbaodian.com

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


6、组的包含与组内变量


[hangzhou]
host1
host2
[jiaxing]
host2
host3
[zhejiang:children]
hangzhou
jiaxing
[zhejiang:vars]
some_server=foo.southeast.example.com
halon_system_timeout=30
self_destruct_countdown=60
escape_pods=2
[china:children]
zhejiang
henan
shandong
hebei

如上面的示例中,我指定了杭州组我有host1、hosts2;嘉兴组我有host3、host4主机;我又指定了一个组浙江组,同时包含杭州和嘉兴;同时为该组内的所有主机指定了四个vars变量。后面我又设定了一个组中国组,包含浙江、河南、山东、河北。


注:由于vars变量在ansible ad-hoc部分中基本用不到,主要用在ansible-playbook中,后面的章节部分也会提到。


以上部分基本上是完全按照官方Inventory 文档部分进行了翻译和微小的变化。英文感觉还可以的可以直接查看官方页面。


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

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

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

直接上一个示例:

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

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


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

  2. 通配符与逻辑或


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


one.linuxbaodian.com
one.linuxbaodian:two.linuxbaodian.com
.168.1.50
.168.1.*

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


*.linuxbaodian.com
*.com

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


web
web:dbservers  //表示两个组中所有的主机

3、逻辑非与逻辑and


当然你可以做出非的表达式,例如,目标主机必须在组web但不在phoenix组中

web:!phoenix

你还可以做出交集的表达式,例如,目标主机必须即在组web中又在组staging中

web:&staging

一个更复杂的示例:

web:dbservers:&staging:!phoenix

上面这个复杂的表达式最后表示的目标主机必须满足:在web或者dbservers组中,必须还存在于staging组中,但是不在phoenix组中。这些可以看作是SaltStack中Compound matchers 。


4、混合高级用法

*.linuxbaodian.com:*.org

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

~(web|db).*\.ct99\.cn

到这里估计你应该用能明白为什么前面我会提到Patterns 可以理解为正则的原因了。最后部分给两个ansible-playbook中具体可能用的用法:


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

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

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

ansible-playbook site.yml --limit datacenter2

以上部分主要按照官方Pattern部分进行翻译和尝试。


评论区

表情

共0条评论
  • 这篇文章还没有收到评论,赶紧来抢沙发吧~

相关内容

点击排行

随机新闻

评论排行榜