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设置一些别名,可以这样做:
web1ansible_ssh_port=3333ansible_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 #用于指定被管理的主机的真实IP
ansible_ssh_port #用于指定连接到被管理主机的ssh端口号,默认是22
ansible_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的类型,默认sh
ansible_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='P@ssw0rd'
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'
上面的示例中指定了三台主机,三台主机的用密码分别是P@ssw0rd、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>
直接上一个示例:
ansiblewebservers-mservice-a"name=httpdstate=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-ewebservers:!{{excluded}}:&{{required}}
b、在ansible和ansible-playbook中,还可以通过一个参数”--limit”来明确指定排除某些主机或组:
ansible-playbooksite.yml--limitdatacenter2
c、从Ansible1.2开始,如果想排除一个文件中的主机可以使用"@":
ansible-playbooksite.yml--limit@retry_hosts.txt
分享到:
相关推荐
4. 知道主机清单:ansible host2 -m ping 5. 错误示范:ansible host4 -m ping -u root -k -o Ansible 的模块: 1. ping 模块:用于测试主机的连通性 2. yum 模块:用于管理 yum 软件包 3. shell 模块:用于执行 ...
坑1 : 动态主机清单配置,需要按照ansible的要求的格式返回给ansible命令的 源代码如下: 但是在ansible-playbook中使用动态主机配置文件的时候,发生了错误!!! 提示没有匹配的主机信息 分析: 数据库已配置好,...
Ansible支持使用变量进行动态配置,这些变量可以在主机清单、playbook或角色中定义。此外,Ansible还会自动收集“事实”——关于被管理主机的信息,如操作系统版本、内存信息等,这些信息可用于动态配置。 9. **...
Ansible安装和配置:包括安装Ansible的步骤、配置主机清单和设置SSH密钥认证。 Ansible模块和插件:介绍Ansible的核心模块和插件,以及如何编写自定义模块和插件。 Ansible任务和剧本:解释如何编写Ansible任务和...
Ansible配置管理数据库 关于 Ansible-cmdb获取Ansible事实收集的输出,并将其转换为包含系统配置信息的静态HTML概述页面(和其他内容)。 它支持多种类型的输出(html,csv,sql等),并使用自定义数据扩展由...
- **配置主机清单**:Ansible 使用 `hosts` 文件作为主机清单,定义了需要管理的服务器列表。可以通过编辑此文件来指定哪些主机需要被管理。 3. **Ansible 基础使用** - **测试连接**:在安装完 Ansible 后,可以...
* 主机清单:/etc/hosts 文件,可以添加主机名对应着节点名称 Ansible 常用术语 * 节点信息、控制节点、受控节点、Inventory、模块、Task、Playbook 等 Ansible 的优点 * 无需安装 agent * 使用 SSH 进行通信 * ...
2. Ansible主机清单 3. Ansible常用模块 4. YAML介绍 Ansible的应用场景包括: 1. 自动化运维:Ansible可以自动化各种类型的系统和环境的运维工作 2. 配置管理:Ansible可以实现批量系统配置和部署 3. 应用程序...
- 主机清单文件:默认位于`/etc/ansible/hosts`,可通过环境变量`ANSIBLE_HOSTS`或 `-i`参数指定。 - 执行命令:例如,`ansible all -m ping`会向所有在主机清单中的主机发送ping模块命令。 Ansible的灵活性和易用...
其中,`<pattern>`是目标主机的模式,`<inventory>`是主机清单文件,`<module>`是Ansible模块,`<mod_args>`是模块参数。 示例: ``` ansible all -m ping ``` 这个命令会向所有主机发送一个ping请求。 2. *...
7. **主机清单(Host Inventory)**:主机清单定义了Ansible管理的主机列表,可以静态配置,也可以动态获取,提供了灵活的主机管理策略。 8. **易用性和学习曲线**:Ansible的设计目标之一就是简单易用,因此它的...
1. **主机清单(Inventory)**:Ansible通过一个主机清单文件来定义要管理的服务器集合。这个清单可以是静态的文本文件,也可以是动态的,根据特定条件生成。在安装过程中,你可能需要创建或修改这个清单来包括你的...
2. 定义清单:定义要管理的主机或设备的清单,可以是静态清单或动态清单。 3. 编写Playbook:编写自动化任务的Playbook,定义自动化任务的执行步骤。 4. 执行任务:使用Ansible命令或Ansible Tower执行自动化任务...
Ansible角色:ansible-bootstrap 为了有效地运行ansible,目标计算机需要具有python解释器。 CoreOS和Flatcar Linux机器最小,并且不附带... 因此,已添加了其他功能,以引导pypy进行ansible控制以及启用ssh堡垒主机pr
这个插件连接到AWS的API,获取当前环境中的实例信息,并将它们作为Ansible的主机清单。这样,我们可以通过定义一组AWS标签或者特定的实例状态,来选择要操作的EC2实例。 在Python标签中,我们可以推断出这个项目...
Linux运维-运维课程d1-自动化工具ansible概述与常用模块-06-ansible主机清单-服务器分
2. **Ansible 配置**:在 Semaphore 中,你需要创建 Ansible playbook 和 roles,定义要执行的任务和主机清单。这些 playbook 将用于自动化部署和管理。 3. **Semaphore 配置**:配置 Semaphore 的数据库连接(通常...
2. **主机清单(Host Inventory)**:定义了被管理主机的配置文件,用于指定操作的目标。 3. **模块(Modules)**:Ansible 的核心功能依赖于这些模块,包括但不限于核心模块、命令模块以及自定义模块等。 4. **插件...
5. **Jinja2 Templating**:Ansible 使用Jinja2模板语言来动态生成配置文件。掌握Jinja2语法能让你创建更强大的配置模板。 6. **Ansible Galaxy**:Galaxy是Ansible的官方角色市场,你可以在这里找到其他人分享的预...