Ansible_variable

Ansible变量

       系统自动化让重复的工作变得更加容易,但是每个系统还是有一些细微的差别,变量就是如何处理系统之间的不同之处。这里将会列出变量的极大部分使用方法。

 

本文假设:你已经知道如何使用Ansible。知道inventory,facts等概念。

 

Ansible定义变量的几中方式

1、在清单(inventory)中定义变量

2、在playbook中定义变量,使用var,或var_files:

3、在role中定义变量

4、自定义facts的变量

5、Register facts ,使用task返回结果作为变量

6、从命令行传递变量

使用变量,除了可用使用自定义的变量,还可以使用facts和其它主机的变量。

 

一、合法变量名

1、必须是字符,数字,下划线组成,变量必须以字符开头。

2、变量支持字典形式的映射。

3、有时候引用变量,使用小数点形式的引用方法可能会和Python内置的属性和方法冲突。建议使用[]形式。

 

二、开始定义与使用变量

1、清单(inventory)变量

1.1定义清单主机变量.在对应的主机后面,提供key=value 形式语句,即可。格式如下

[webserver]
172.16.1.10 ansible_ssh_user=root inventory_host_var="Host_vars"
172.16.1.20 ansible_ssh_user=root

1.2定义清单组变量,格式如下。

[webserver:vars]
inventory_group_var="Group_vars"

1.3 可以根据对应的inventory创建文件,写入变量

mkdir /etc/ansible/host_vars     #Ansible会默认读取此目录下对应的主机名文件
mkdir /etc/ansible/group_vars    #同上
vim  /etc/ansible/host_vars/all 或者 vim  /etc/ansible/host_vars/hostname
vim /etc/ansible/group_vars/groupname

在文件中写入变量即可。格式为ymal格式文件。


2、在playbook中定义变量

---
- hosts: hostname or groupname
  vars:                       #playbook中定义变量的关键字
   playbook_var: Playbook_vars
  var_files:                  #使用变量文件
   - filename.yml 
  tasks:
  - name: Copy Jinja2 file to remote host
    template: src=/home/aheahe/var_tu.j2 dest=/root/var.conf


3、在role中定义变量

mkdir roles/test/{vars,files,templates,tasks,defaults,handlers} -p  #创建role结构
vim roles/test/vars/main.yml     #1、编辑task文件
---
role_vars_var: Role_vars_var
vim roles/test/defaults/main.yml   #2、编辑默认变量文件
---
role_defaults_var: Role_default_var
vim roles/test/tasks/main.yml     #3、编辑roles var文件
--- 
- name: Learn role vars
  template: src=1.j2 dest=/root/1
vim roles/test/templates/1.j2    #4、编辑模板文件
{{ role_vars_var }}
{{ role_defaults_var }}
vim site.yml                   #5、编辑执行文件
---
- hosts: 172.16.1.10
  roles:
  - /home/aheahe/roles/test
ansible-playbook site.yml   #6、执行
[172.16.1.10~]# cat 1    #7、在被管理节点上查看结果
 
Role_vars_var
Role_default_var

Tip:在引用role的时候,还可以传递变量给role

- hosts: webservers
  roles:
   - common
   - {  role: test, role_defaults_var: 'var_value'  }


4、自定义Facts变量。

如果在被管理的主机上存在/etc/ansible/facts.d 目录,其中的以.fact 为文件结尾的JSON格式或者YML格式文件都会当做自定义facts。

[172.16.1.10]# vim /etc/ansible/facts.d/local.fact  #编辑自定义facts文件
[general]
Aheahe=aihe
local="Local facts"
[ansible ~]$ansible 172.16.1.10 -m setup -a 'filter=ansible_local'  #在ansible控制节点查看自定义facts变量是否生效
172.16.1.10 | success >> {
    "ansible_facts": {
        "ansible_local": {
            "local": {
                "general": {
                    "aheahe": "aihe",
                    "local": "\"Local facts\""
                }
            }
        }
    },
    "changed": false
}

 

可以像fact一样使用,自定义的fact变量。

vim roles/test/templates/1.j2   #使用刚才的角色
{{ role_vars_var }}
{{ role_defaults_var }}
{{ ansible_local.local.general.local }}
ansible-playbook site.yml   #执行刚才的site.yml
[172.16.1.10 -]# cat /root/1    #被管理节点查看结果,显示正确
Role_vars_var
Role_default_var
"Local facts"

4.1这里还可以在控制节点上面传递自定义变量到被管理节点,编辑如下ymal格式文件。

- hosts: webservers
  tasks:
    - name: create directory for ansible custom facts
      file: state=directory recurse=yes path=/etc/ansible/facts.d
    - name: install custom impi fact
      copy: src=ipmi.fact dest=/etc/ansible/facts.d
    - name: re-readfacts after adding custom fact
      setup: filter=ansible_local

5、定义Register变量,

Register变量是将task的结果信息当做变量使用。在任务的执行结果后面加上register 关键字即可定义变量

vim study.yml 
---
- hosts: 172.16.1.10
  vars:
   playbook_var: Playbook_vars
  tasks:
  - name: Learn Register
    shell: ifconfig
    register: command_result
 
  - name: Test register
    shell: date
    when: command_result.rc == 0
ansible-playbook study.yml -v   #执行的时候加上-v 选项。查看输出信息


6、从命令行传递变量.

相信这点对大家来说已经不成问题了,便不再细说

ansible-playbook release.yml --extra-vars "version=1.23.45 other_variable=foo"  #传递key=value形式变量
--extra-vars '{"pacman":"mrs","ghosts":["inky","pinky","clyde","sue"]}'  #传递JSON格式变量
--extra-vars "@some_file.json"    #传递JSON格式文件变量

三、使用变量

上面在举例子的时候,已经说明如何使用了。下面介绍如何使用fact变量和一台主机使用另外一台主机的变量。

使用实现定义好的变量,在变量两边加上大括号,格式为{{ var_name }}

vim var.j2
{{ ansible_hostname  }}   #这里是使用fact变量,两个主机的结果不一样
{{ hostvars['172.16.1.10']['ansible_hostname'] }}  #这里两台主机的结果一样,node2>使用node1的变量
vim test.yml   #提供剧本
---
- hosts: webserver
  tasks:
  - name: Use fact and other host vars
    template: src=/home/aheahe/playbook/var.j2 dest=/root/var.conf
ansible-playbook test.yml  #执行
[root@node1]# cat /root/var.conf     #这里可以看到node2使用node1的变量。
node1   #这里是使用fact变量,两个主机的结果不一样
node1  #这里两台主机的结果一样,node2使用node1的变量

四、变量的优先级。处理同一个变量名多处定义的问题。

3.1、在1.x版本里面,越靠下优先级越高,可以覆盖上面的

1、role defaults 中定义的变量,优先级最低

2、从被管理系统中收集的facts信息

3、inventory中定义的变量

4、在playbook中的vars: 或者 roles 中的vars

5、一些连接变量,例如ansible_user 。

6、命令行的变量  ansible-playbook -e 选项的变量, 优先级别最高。

3.2 ,在2.x系列的版本中调整变量优先级的顺序为如下。优先级由低到高

  1. role defaults 

  2. inventory vars 

  3. inventory group_vars

  4. inventory host_vars

  5. playbook group_vars

  6. playbook host_vars

  7. host facts

  8. registered vars

  9. set_facts

  10. play vars

  11. play vars_prompt

  12. play vars_files

  13. role and include vars

  14. block vars (only for tasks in block)

  15. task vars (only for the task)

  16. extra vars


参考:

http://docs.ansible.com/ansible/playbooks_variables.html

原创文章,作者:艾贺,如若转载,请注明出处:http://www.178linux.com/9431

(0)
艾贺艾贺
上一篇 2015-11-26 16:41
下一篇 2015-11-26 17:26

相关推荐

  • 访问控制列表ACL

     ACL是Access Control List的缩写,主要的目的是提供传统的owner、group、others的read、write、execute权限之外的具体权限设置。ACL可以针对单一用户、单一文件、单一目录来进行r、w、x的权限设置,对于需要特殊权限的使用状况非常有帮助。使用getfacl和setfacl来设置查看acl的权限。ACL权…

    Linux干货 2016-08-07
  • 第五周作业

    1、显示/boot/grub/grub.conf中以至少一个空白字符开头的行; ~]# grep  “^[[:space:]]\{1,\}” /boot/grup/grup.conf                     &…

    2017-03-01
  • 第二十二周作业

    1、请描述本地文件系统和分布式文件系统的特点 本地文件系统 本地文件系统主要是指Ext2,Ext3,Btrfs,XFS这类,它们通常提供以下功能: 扩展性:随着系统容量的增加保持性能,不随容量变化而导致性能震荡。比如一个目录下的海量文件,在EXT2/3中由于目录设计问题会导致较大的性能问题。再比如EXT2/3中的Metadata的占用和inode的划分可能会…

    2017-08-06
  • N25-第九周

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash #统计shell及非shell个数 #author:dodo declare -i loginnum=0 declare -i nologinnum=0 while…

    Linux干货 2017-05-27
  • bash

    bash 配置文件   按生效范围划分:存在两类;     全局配置:            /etc/profile       &nbs…

    Linux干货 2015-04-15
  • 第1周-1:计算机的组成及其功能以及部分常见Linux发行版简介

    一、计算机的组成及其功能: 计算机主要由硬件部分和软件部分组成。 1、硬件部分 (1)中央处理器 由控制器和运算器两大部分组成,是计算机的大脑,硬件部分里最关键的部分。决定着整个计算机系统的性能。 控制器负责协调计算机硬件的其他部分同步工作,对其他的硬件进行发号施令。是计算机系统的司令。控制器从存储器中读取指令,分析指令的含义,要完成什么操作,需要什么数据,…

    Linux干货 2016-11-01