ansible进阶02

管理主机清单变量

使用变量的原则

变量创建的位置
  • 角色的defaults或vars目录
  • 主机清单
  • playbook或主机清单所在位置的子目录group_varshost_vars
  • play或角色或任务

无论在哪创建变量,都应该遵守一些规则:

  • 保持简洁
  • 不要重复造轮子。不要反复在多个位置创建相同的变量。
  • 把变量组织到小的、可读性强的文件中

变量的合并和优先级

主机清单变量优先级从低到高

  • 角色defaults中的变量
  • 主机清单中定义的组变量
  • inventory目录下group_vars/all目录中为主机组all定义的组变量
  • playbook目录下group_vars/all目录中为playbook定义的组变量
  • inventory目录下group_vars目录中为其他主机组定义的组变量
  • playbook目录下group_vars目录中为playbook定义的组变量
  • 主机清单中定义的主机变量
  • 在主机清单的host_vars目录中创建的变量
  • 在playbook的hosts_vars目录中创建的变量
  • facts变量和缓存变量

play变量的优先级

从低到高依次是:

  • play中通过vars声明的变量
  • play中通过vars_prompt获取的变量
  • play中通过vars_files声明的变量
  • 角色的vars目录中声明的变量
  • block中通过vars声明的变量
  • task中通过vars声明的变量
  • 通过include_vars加载的变量
  • 通过set_fact模块创建的变量和通过register注册的变量
  • 当加载角色时导入的参数,或通过include_role模块加载的参数
  • 通过include_tasks模块设置的变量
  • 通过ansible-playboo -e指定的额外变量

将变量从主机清单中分离出来

  • 建议的组变量结构
shell 复制代码
[user@demo project3]$ tree -F group_vars
group_vars/                 # 组变量定义目录
├── all/                    # 组all
│   └── common.yml          # 定义所有组都需要的变量
├── db_servers/             # 组db_servers
│   ├── mysql.yml           # 定义mysql相关的变量,文件名随意
│   └── firewall.yml
├── lb_servers/
│    ├── firewall.yml
│    ├── haproxy.yml
│    └── ssl.yml
└── web_servers/
     ├── firewall.yml
     ├── webapp.yml
     └── apache.yml
特殊的主机变量
  • ansible_connection:用于指定连接方式(ssh、smart、local)。
  • ansible_host:当连接到被管理的主机时,使用的真实的IP地址或FQDN。
  • ansible_port:远程主机的端口号。
  • ansible_user:远程连接时采用的用户。
用于识别主机的变量
  • inventory_hostname:主机清单中的主机名
  • ansible_host:主机的真正IP地址,或FQDN
  • ansible_facts['hostname']:事实变量取得的主机名
  • `ansible_facts['fqdn']:事实变量取得的FQDN
相关推荐
重启就好12 小时前
【Ansible】之inventory主机清单
运维·ansible
xmweisi0214 小时前
Ansible内置模块之 group
linux·运维·ansible·rhce·rhca·红帽认证
一直奔跑在路上1 天前
【Ansible】基于windows主机,采用NTLM+HTTPS 认证部署
windows·https·ansible
遇见火星2 天前
Ansible模块——从控制节点向目标主机复制文件!
java·服务器·ansible
重启就好3 天前
【Ansible】模块详解
linux·服务器·ansible
是垚不是土3 天前
Kolla-Ansible搭建与扩容OpenStack私有云平台
linux·运维·服务器·云计算·ansible·openstack
xmweisi025 天前
Ansible内置模块之package
linux·ansible·rhce·rhca·红帽认证·it培训
xmweisi025 天前
Ansible内置模块之service
linux·ansible·rhce·rhca·红帽认证
企鹅侠客6 天前
Ansible 流程控制
ansible·ansible流程控制