Ansible 系列之 Patterns
Ansible 之 Patterns
1.Ansible中的Patterns决定了我们要管理哪个主机,意思是与哪些主机进行交互。
我们将在Ad-Hoc(Ad-Hoc 是指 临时执行的命令,要结合着模块进行使用,可通过ansible-doc -l查看模块的列表)命令行中进行介绍,
本文中,ansible 的hosts 清单文件内容如下:
[root@docker ~]# cat /etc/ansible/hosts
[centos_group]
172.17.0.2
172.17.0.3 [webserver]
web1 ansible_port= ansible_host=172.17.0.4
172.17.0.3 [centos:children]
centos_group
webserver
先看下命令行模式的语法:
ansible <pattern_goes_here> -m <module_name> -a <arguments>
示例:
[root@docker ~]# ansible webserver -m shell -a "date"
web1 | SUCCESS | rc= >>
Mon Feb :: CST
-m 模块名,默认不指定,使用的是command 模块。
-a 模块参数,可通过 `ansible-doc 模块名` 查看具体使用方法
在上面的示例中 pattern_goes_here 指的是webserver 组中的计算机,
下面的两条命令中的patterns 等价于使用清单中内的所有主机
[root@docker ~]# ansible "*" -m shell -a "date"
[root@docker ~]# ansible all -m shell -a "date"
也可以按指定ip地址,如:
[root@docker ~]# ansible 172.17.0.2 -m ping
172.17.0.2 | SUCCESS => {
"changed": false,
"ping": "pong"
}
[root@docker ~]# ansible 172.17..* -m ping
172.17.0.3 | SUCCESS => {
"changed": false,
"ping": "pong"
}
172.17.0.2 | SUCCESS => {
"changed": false,
"ping": "pong"
}
有个有趣的小发现,不知当桨不当桨。ping 对应的是 pong,是乒乓的意思么?
patterns 是一个组,也可用 冒号:分割,添加另外一个组,表示主机可以在这个组或者另一组中。
如下:
[root@docker ~]# ansible centos_group:webserver -m ping
172.17.0.3 | SUCCESS => {
"changed": false,
"ping": "pong"
}
web1 | SUCCESS => {
"changed": false,
"ping": "pong"
}
172.17.0.2 | SUCCESS => {
"changed": false,
"ping": "pong"
}
也可以排除某个组相同的主机,如所有计算机必须在centos_group组中 且不在webserver 组中,用 :!来表示(!、& 会被bash 解释,所以需要加转义符),如下:
[root@docker ~]# ansible centos_group:\!webserver -m ping
172.17.0.2 | SUCCESS => {
"changed": false,
"ping": "pong"
}
还可以指定两个组的交集,意味着主机必须即在webserver 组中,又在centos_group组中,用:& 表示,如下:
[root@docker ~]# ansible centos_group:\&webserver -m ping
172.17.0.3 | SUCCESS => {
"changed": false,
"ping": "pong"
}
另外也可以根据数组下标来选择组内的主机,如下:
[root@docker ~]# ansible centos_group[] -m ping
172.17.0.2 | SUCCESS => {
"changed": false,
"ping": "pong"
}
当然,还有高级的用法,如利用通配符,以及正则的方式来匹配主机。
等下再来学习Ad-Hoc 命令的使用吧。
注:本文属于飞走不可原创,如有转载,请务必在文首注明出处。飞走不可:=_= http://www.cnblogs.com/hanyifeng/p/6193249.html
Ansible 系列之 Patterns的更多相关文章
- Ansible系列(二):选项和常用模块
html { font-family: sans-serif } body { margin: 0 } article,aside,details,figcaption,figure,footer,h ...
- Ansible系列(一):基本配置和使用
本文目录:1.1 安装Ansible1.2 配置Ansible 1.2.1 环境配置 1.2.2 SSH互信配置 1.2.3 简单测试1.3 inventory Ansible是一种批量.自动部署工具 ...
- Ansible系列(五):playbook应用和roles自动化批量安装示例
html { font-family: sans-serif } body { margin: 0 } article,aside,details,figcaption,figure,footer,h ...
- Ansible系列(六):各种变量定义方式和变量引用
本文目录:1.1 ansible facts1.2 变量引用json数据的方式 1.2.1 引用json字典数据的方式 1.2.2 引用json数组数据的方式 1.2.3 引用facts数据1.3 设 ...
- Ansible系列(三):YAML语法和playbook写法
html { font-family: sans-serif } body { margin: 0 } article,aside,details,figcaption,figure,footer,h ...
- Ansible系列(六):循环和条件判断
本文目录:1. 循环 1.1 with_items迭代列表 1.2 with_dict迭代字典项 1.3 with_fileglob迭代文件 1.4 with_lines迭代行 1.5 with_ne ...
- Ansible系列(七):执行过程分析、异步模式和速度优化
本文目录:1.1 ansible执行过程分析1.2 ansible并发和异步1.3 ansible的-t选项妙用1.4 优化ansible速度 1.4.1 设置ansible开启ssh长连接 1.4. ...
- Ansible系列(四):playbook应用和roles自动化批量安装示例
Ansible系列文章:http://www.cnblogs.com/f-ck-need-u/p/7576137.html playbook是ansible实现批量自动化最重要的手段.在其中可以使用变 ...
- Ansible系列(五):各种变量定义方式和变量引用
Ansible系列文章:http://www.cnblogs.com/f-ck-need-u/p/7576137.html 1.1 ansible facts facts组件是用来收集被管理节点信息的 ...
随机推荐
- 两天快速开发一个自己的微信小程序
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px "Songti SC" } p.p2 { margin: 0.0px 0. ...
- gdb的多线程调试
info threads 可以查看当前进程有哪些线程 thread ID 可以切换到线程ID bt 查看当前线程堆栈 set scheduler-locking on多线程调试过程中, 线程会来回切换 ...
- 一个三维点类Gpoint3的实现
1 类设计 基本功能 (1)默认构造时,自动初始化为(0,0,0): (2)支持点之间的加.减运算: (3)支持点与常量数据的加.减.乘除运算: (4)支持点之间的相等或不能判断 (5)如果把点类看作 ...
- 详解spl_autoload_register()函数
一.__autoload 这是一个自动加载函数,在PHP5中,当我们实例化一个未定义的类时,就会触发此函数.看下面例子: printit.class.php <?php class ...
- JAVA IO分析一:File类、字节流、字符流、字节字符转换流
因为工作事宜,又有一段时间没有写博客了,趁着今天不是很忙开始IO之路:IO往往是我们忽略但是却又非常重要的部分,在这个讲究人机交互体验的年代,IO问题渐渐成了核心问题. 一.File类 在讲解File ...
- 5、C#基础 - C#的值类型
1.C#的值类型 有几个特点: 存储在栈里 基于值类型的变量直接包含值(值类型存储实际值). 将一个值类型变量赋给另一个值类型变量时,将复制包含的值. 这与引用类型变量的赋值不同,引用类型变量的赋值只 ...
- ElasticSearch 学习记录之 分布式文档存储往ES中存数据和取数据的原理
分布式文档存储 ES分布式特性 屏蔽了分布式系统的复杂性 集群内的原理 垂直扩容和水平扩容 真正的扩容能力是来自于水平扩容–为集群添加更多的节点,并且将负载压力和稳定性分散到这些节点中 ES集群特点 ...
- Tabhost最纯净的实现方式
有时候常常使用别人用Tabhost+其他的实现demo.单纯利用Tabhost该怎样使用呢? 以下看样例: public class MainActivity extends TabActivity ...
- Win32界面 主函数分析
WinMain即(函数运行入口): p { margin-bottom: 0.25cm; line-height: 120% } int WINAPI WinMain (HINSTANCE hinst ...
- Elasticsearch布尔查询——bool
布尔查询允许我们利用布尔逻辑将较小的查询组合成较大的查询. 1.查询返回包含"mill"和"lane"的所有的账户 curl -XPOST 'localhost ...