概览
控制Ansible行为的方式有很多,基本分为如下4种:
- 配置文件
- 命令行参数
- playbook关键词
- 变量
比如主机清单位置,默认是/etc/ansible/hosts
,也可以通过命令行参数- i
更改,也可以通过修改配置文件更换默认主机清单位置;playbook里可以控制执行用户,在主机变量里也可以控制
上面4种配置方法,优先级从低到高,简单来说就是后面定义的内容会覆盖前面的,配置文件的优先级是最低的,本篇文章重点说一说Ansible常用的一些配置项
配置文件路径
Ansible按照下面的顺序寻找配置文件,首先找到的被使用,不再进行后续查找(即被忽略)
- ANSIBLE_CONFIG 环境变量
- ansible.cfg 当前路径
- ~/.ansible.cfg 家目录
- /etc/ansible/ansible.cfg
如果我们希望测试一份配置文件,而不想影响其它配置文件,可以像下面这样
ANSIBLE_CONFIG=/tmp/ansible.cfg ansible all -m ping
#这种情况变量 ANSIBLE_CONFIG ,仅仅对当前这一行命令生效
配置文件注释
分为两种情况
1 注释书写在开头部分(顶格写或者前面是空格),使用 #
或 ;
# cat /etc/ansible/ansible.cfg
# config file for ansible -- https://ansible.com/
# ===============================================# nearly all parameters can be overridden in ansible-playbook
...
2 注释在中间,只能使用;
(不太常用)
cat /etc/ansible/ansible.cfg
...
inventory = /etc/ansible/hosts ; This points to the file that lists your hosts
...
配置的基本格式
如果是全新安装,可以参考cat /etc/ansible/ansible.cfg
;该配置文件的线上地址是https://raw.githubusercontent.com/ansible/ansible/devel/examples/ansible.cfg
,其基本格式如下
# 注释
# 注释
# 下面这个 [defaults] 是分组名称
[defaults]
inventory = /etc/ansible/hosts
#library = ~/.ansible/plugins/modules:/usr/share/ansible/plugins/modules[inventory]
# List of enabled inventory plugins and the order in which they are used.
#enable_plugins = host_list, script, auto, yaml, ini, toml
ansible-config
ansible的配置项有很多,不同ansible版本配置项略有不同,绝大多数无需关注,不用更改。最方便的得知我们当前安装的ansible版本有哪些可用的配置项,是使用ansible-config
命令
[root@192_168_31_106 ~]# ansible-config -h
usage: ansible-config [-h] [--version] [-v] {list,dump,view} ...View ansible configuration.positional arguments:{list,dump,view}list Print all config optionsdump Dump configurationview View configuration fileoptional arguments:--version show program's version number, config file location,configured module search path, module location, executablelocation and exit-h, --help show this help message and exit-v, --verbose verbose mode (-vvv for more, -vvvv to enable connectiondebugging)
ansible-config list
比如我们想要更改默认主机清单的位置,可以搜索inventory关键词,查看帮助,示例如下
ansible-config dump[root@192_168_31_106 ~]# ansible-config dump > /tmp/tmp.txt && fgrep '/etc/ansible' /tmp/tmp.txt
DEFAULT_FORKS(/etc/ansible/ansible.cfg) = 20
DEFAULT_HOST_LIST(default) = [u'/etc/ansible/hosts']
DEFAULT_ROLES_PATH(default) = [u'/root/.ansible/roles', u'/usr/share/ansible/roles', u'/etc/ansible/roles']
参考常用配置项
全部配置项可以使用上文ansible-config
命令得到,也可以直接到官方文档里查看(见文章最后的参考资料),下面介绍一下常用的配置项
一个示例
#1 主机清单的位置,还可以设置成目录,此时目录里的文件名不关键,主要是文件里内容中括号的部分,作为机器分组的名称
inventory = /etc/ansible/hosts
比如说,我们可以有下面的目录结构
# tree inventory
├── web
├── golang
├── griddns
├── group_vars
│ ├── admin5_php-fpm_bx.yml
│ ├── admin5_php-fpm_yf3.yml
│ ├── all.yml
│ ├── bt_ctorrent_bx.yml
│ ├── bt_hwraid_bx.yml
│ ├── ceph_bx.yml
│ ├── ceph_dbl.yml
├── host_vars
│ ├── 10.13.32.100.yml
│ ├── 10.13.32.101.yml
│ ├── 10.13.32.102.yml
│ ├── 10.13.32.103.yml
│ ├── 10.13.32.104.yml
│ ├── 10.13.32.110.yml#2 并发执行的数量
forks = 5#3 目标机器的SSH端口
remote_port = 26387#4 角色查找路径
roles_path = /usr/local/myansible/roles#5 SSH连接超时时间
timeout = 10
参考资料
https://docs.ansible.com/ansible/latest/reference_appendices/config.html
https://docs.ansible.com/ansible/latest/cli/ansible-config.html
https://docs.ansible.com/ansible/latest/reference_appendices/general_precedence.html