【Ansible 文档】【译文】模式
Patterns 模式
Ansible中的模式是指我们如何决定那些机器执行管理操作。这里意味着与那些主机通信,但是对于playbook,它是指哪些主机应用特定的配置或执行特定程序。
我们将重温一下Introduction To Ad-Hoc Commands部分如何使用命令行,命令格式如下:
ansible <pattern_goes_here> -m <module_name> -a <arguments>
例如:
ansible webservers -m service -a "name=httpd state=restarted"
一个模式,通常指组(主机集)的集合,在上面这个例子中,webservers组机器集合。
不管怎么样,在使用Ansible前,我们首先要知道,如何告诉Ansible与inventory文件中哪些机器通信。 这就需要设计特殊的、专用的、唯一的、 host 名 或者 主机组。
以下的模式是相等的,都是选择所有的主机:
all
*
指定一个特定的主机或者主机名集合也是可以的:
one.example.com
one.example.com:two.example.com
192.0.2.50
192.0..*
下面的模式指定了一个或多个组,组间用冒号分割,表示“或 - OR”,这意味着存在任意一组内都会被选择:
webservers
webservers:dbservers
你也可以排除某一组,例如所有的机器都必须是webservers 中,同时不能在 phoenix 组中:
webservers:!phoenix
你也可以指定俩个组的交集。这意味着只有俩个组中都包含的主机才会被选择:
webservers:&staging
组合使用:
webservers:dbservers:&staging:!phoenix
上面的例子意思是:存在webservers组中或者dbservers组中的主机集合,如果主机也在staging组中而不在phoenix组中,将被选择。
你可以使用变量,如果你想要传递某些组说明符到playbook中,通过 “-e” 参数,但这不是常见用法。
webservers:!{{excluded}}:&{{required}}
你也不必通过严格定义的组来管理。单个的主机名、IPs和组也可以使用通配符指定。
*.example.com
*.com
如果你想同时混合模式和组:
one*.com:dbservers
你可以选择组中的一台主机或者主机子集。例如,在如下的例子时:
[webservers]
cobweb
webbing
weber
你可以指定组中的主机通过添加下标到组名上:
webservers[] # == cobweb
webservers[-] # == weber
webservers[:] # == webservers[],webservers[]
# == cobweb,webbing
webservers[:] # == webbing,weber
大多数不会指定模式为正则表达式,但是你也可以这么做。通过在模式的头部添加一个 '~' 即可:
~(web|db).*\.example\.com
此外,我们可以更进一步,你可以添加一个包含条件,通过提供 --limit 标识到 /usr/bin/ansible 或者 /usr/bin/ansible-playbook:
ansible-playbook site.yml --limit datacenter2
并且,如果你想从文件中获取主机列表,在文件名前面添加‘@’字符。Ansible 1.2之后可用。
ansible-playbook site.yml --limit @retry_hosts.txt
See Introduction To Ad-Hoc Commands and then Playbooks for how to apply this knowledge。
注意:
Ansible 1.9可以使用 “,” 代替“:”作为主机分隔符。“,”是一个更好的方式,当处理ranges和ipv6时。
当Ansible 2.0之后,“;”不再作为主机分隔符。
【Ansible 文档】【译文】模式的更多相关文章
- 【Ansible 文档】【译文】配置文件
这里说明一下配置文件的内容,原文地址:http://docs.ansible.com/ansible/latest/intro_configuration.html 这个与[Ansible 文档]配置 ...
- 【Ansible 文档】【译文】Playbooks 变量
Variables 变量 自动化的存在使得重复的做事情变得很容易,但是我们的系统不可能完全一样. 在某些系统中,你可能想要设置一些与其他系统不一样的行为和配置. 同样地,远程系统的行为和状态也可以影响 ...
- 【Ansible 文档】【译文】Windows 支持
see also:List of Windows Modules Windows Support Windows 支持 Windows: How Does It Work Windows:如何工作 正 ...
- 【Ansible 文档】【译文】Ad-Hoc 命令介绍
Introduction To Ad-Hoc Commands Ad-Hoc命令介绍 下面的例子展示了如何使用 /usr/bin/ansible 来运行ad hoc任务. 什么是ad hoc命令? 一 ...
- 【Ansible 文档】【译文】入门教程
http://docs.ansible.com/ansible/latest/intro_getting_started.html Foreword 前言 到这里,你应该已经安装了Ansible,是时 ...
- 【Ansible 文档】【译文】网络支持
Networking Support 网络支持 Working with Networking Devices 使用网络设备 自从Ansible 2.1开始,你现在可以使用成熟模型 - 编写 play ...
- 【Ansible 文档】【译文】常见问题
http://docs.ansible.com/ansible/latest/faq.html 如何为一个task或者整个Playbook设置PATH或者任意其他环境变量? 通过environment ...
- 【Ansible 文档】【译文】动态inventory
Dynamic Inventory 动态inventory 配置管理系统的用户经常想要保存inventory到不同的软件系统中.Ansible提供了一个基本的基于文本的系统,正如inventory中描 ...
- 【Ansible 文档】【译文】主机清单文件
Inventory 主机清单文件 Ansible 可以对你的基础设施中多个主机系统同时进行操作.通过选择在Ansible的inventory列出的一部分主机来实现.inventory默认保存在/etc ...
随机推荐
- Spring学习之路-从放弃到入门
AOP:方法拦截器 IOC:类管理容器 主要讲讲这一天看Spring视频学到的东西,以下的叫法全是自创的. 1.类实例管理容器 关于Spring,首先是对类的管理,在常规情况,生成一个类需要调用new ...
- params关键字、工具辅助类与、加密与解密
一.params关键字 在C#中如果给方法的参数加上关键字params则会形成可变参数,在传递时可以是0-n个对象. 示例: using System; using System.Collection ...
- WCF 学习总结1 -- 简单实例
从VS2005推出WCF以来,WCF逐步取代了Remoting, WebService成为.NET上分布式程序的主要技术.WCF统一的模型整合了以往的 WebService.Remoting.MSMQ ...
- Razor 中的@rendersection
在使用布局页时,可以指定页面中某处的渲染,具体的用@rendersection来做.如在布局页中要渲染一段自定义的脚本, @RenderSection("scripts", req ...
- Oracle数据库基本常用命令汇总
1.得到数据库名和创建日期SELECT name, created, log_mode, open_mode FROM v$database; 2.ORACLE数据库的计算机的主机名,ORACLE数据 ...
- SSH无密码登录的原理及配置
一.SSH概念(百度) SSH 为 Secure Shell 的缩写,由 IETF 的网络小组(Network Working Group)所制定:SSH 为建立在应用层基础上的安全协议.SSH 是目 ...
- eclipse设置成保护眼的背景色
长时间的使用eclipse开发会很累吧 设置一个保护眼睛的豆沙绿色 不刺眼 是不是会更好一些呢 那么如何设置呢现在就教大家 工具/原料 eclipse jdk 方法/步骤 首先打开eclipse ...
- MySQL数据库的配置
一.配置MySQL数据库 MySQL的官网www.mysql.com 1.解压绿色版mysql,并改名为mysql5.7,如下图 对比一下下图5.6以前的版本,少data目录(存放数据)和my-def ...
- OpenStack的架构详解[精51cto]
OpenStack既是一个社区,也是一个项目和一个开源软件,它提供了一个部署云的操作平台或工具集.其宗旨在于,帮助组织运行为虚拟计算或存储服务的云,为公有云.私有云,也为大云.小云提供可扩展的.灵活的 ...
- django-xss攻击原理与防范
一.跨站脚本攻击(XSS) XSS是一种经常出现在web应用中的计算机安全漏洞,它允许恶意web用户将代码植入到提供给其它用户使用的页面中.也属一种注入攻击,注入本质上就是把输入的数据变成可执行的程序 ...