控制Ansible行为的方式有很多,基本分为如下4种:
比如主机清单位置,默认是/etc/ansible/hosts
,也可以通过命令行参数- i
更改,也可以通过修改配置文件更换默认主机清单位置;playbook里可以控制执行用户,在主机变量里也可以控制
上面4种配置方法,优先级从低到高,简单来说就是后面定义的内容会覆盖前面的,配置文件的优先级是最低的,本篇文章重点说一说Ansible常用的一些配置项
Ansible按照下面的顺序寻找配置文件,首先找到的被使用,不再进行后续查找(即被忽略)
如果我们希望测试一份配置文件,而不想影响其它配置文件,可以像下面这样
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的配置项有很多,不同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 options
dump Dump configuration
view View configuration file
optional arguments:
--version show program's version number, config file location,
configured module search path, module location, executable
location and exit
-h, --help show this help message and exit
-v, --verbose verbose mode (-vvv for more, -vvvv to enable connection
debugging)
查看全部可用配置项
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