Ansible剧本管理
inventory主机清单
ansible默认的主机清单是/etc/ansible/hosts文件,主机清单可以手动设置,也可以通过Dynamic Inventory动态生成,一般主机名使用FQDN
vim /etc/ansible/hosts
[webserver]
www1.example.org
www2.example.org:2222
如果是名称类似的主机,可以使用列表的方式标识各个主机
[webserver]
www[01:50].example.org ansible_ssh_user=root ansible_ssh_pass=123456
[dbbservers]
db-[a:f].example.org
inventory变量
[webserver]
www1.magedu.com http_port=80 maxRequestsChild=808
www2.magedu.com http_port=8080 maxRequestsChild=909
[servers:vars]
ntp_server=ntp.example.org
nfs_server=nfs.example.org
[apache]
http1.example.org
http2.example.org
[nginx]
ngx1.example.org
ngx2.example.org
[webservers:children]
apache
nginx
参数 |
说明 |
ansible_ssh_host |
将要连接的远程主机名.与你想要设定的主机的别名不同的话,可通过此变量设置 |
ansible_ssh_port |
ssh端口号.如果不是默认的端口号,通过此变量设置 |
ansible_ssh_user |
默认的 ssh 用户名 |
ansible_ssh_pass |
ssh 密码(这种方式并不安全,我们强烈建议使用 --ask-pass 或 SSH 密钥) |
ansible_ssh_private_key_file |
ssh 使用的私钥文件.适用于有多个密钥,而你不想使用 SSH 代理的情况 |
ansible_ssh_common_args |
此设置附加到sftp,scp和ssh的缺省命令行 |
ansible_sftp_extra_args |
此设置附加到默认sftp命令行 |
ansible_scp_extra_args |
此设置附加到默认scp命令行 |
ansible_ssh_extra_args |
此设置附加到默认ssh命令行 |
ansible_ssh_pipelining |
确定是否使用SSH管道. 这可以覆盖ansible.cfg中得设置 |
ansible_shell_type |
目标系统的shell类型.默认情况下,命令的执行使用 ‘sh’ 语法,可设置为 ‘csh’ 或 ‘fish’ |
ansible_python_interpreter |
目标主机的 python 路径.适用于的情况: 系统中有多个 Python, 或者命令路径不是"/usr/bin/python",比如 *BSD, 或者 /usr/bin/python |
ansible_*_interpreter |
这里的"*"可以是ruby 或perl 或其他语言的解释器,作用和ansible_python_interpreter 类似 |
ansible_shell_executable |
这将设置ansible控制器将在目标机器上使用的shell,覆盖ansible.cfg中的配置,默认为/bin/sh |
YAML标记语言
YAML:另一种标记语言。是用来写配置文件的语言,非常简洁和强大。
YAML语法和其他语言类似,也可以表达散列表、标量等数据结构。
结构通过空格来展示;序列里配置项通过-来代表;Map里键值用:来分隔;YAML的扩展名为yaml
1.大小写敏感
2.使用缩进表示层级关系
3.缩进时不允许使用Tab键,只允许使用空格。
4.缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
1.对象:键值对的集合,又称为映射(mapping)/ 哈希(hashes) / 字典(dictionary)
例如:name:Example Developer
键 值
2.数组:一组按次序排列的值,又称为序列(sequence) / 列表(list)
例如:-Apple
-Orange
3.纯量:单个的、不可再分的值
例如:number:12.30
sure:true
yaml实例:
name:zhangsan
age:20
name:lisi
age:22
people:
-name:zhangsan
age:20
-name:lisi
age:22
Ansible剧本-playbook
Playbook是一种完全不同的运用ansible的方式,类似与saltstack的state状态文件。ad-hoc无法持久使用,playbook可以持久使用。
playbook是由一个或多个play组成的列表,play的主要功能在于将事先归并为一组的主机装扮成事先通过ansible中的task定义好的角色。从根本上来讲,所谓的task无非是调用ansible的一个module。将多个play组织在一个playbook中,即可以让它们联合起来按事先编排的机制完成某一任务。通过task调用ansible的模板将多个play组织在一个playbook中运行。
Playbook核心元素
名称 |
含义 |
Hosts |
执行的远程主机列表 |
Tasks |
任务集,即调用模块完成的某操作 |
Varniables |
变量,内置变量或自定义变量在playbook中调用 |
Templates |
模板,即使用模板语法的文件,比如配置文件等 |
Handlers |
处理器,和notity结合使用,由特定条件触发的操作,满足条件方才执行,否则不执行 |
tags |
标签,指定某条任务执行,用于选择运行playbook中的部分代码 |
Roles |
角色 |
Playbook语法
1、playbook使用yaml语法格式,后缀可以是yaml,也可以是yml。
在单一的一个playbook文件中,可以连续三个连子号(---)区分多个play。还有选择性的连续三个点好(...)用来表示play的结尾,也可省略。
2、当行开始正常写playbook的内容,一般都会写上描述该playbook的功能。