zoukankan      html  css  js  c++  java
  • Ansible Playbook 变量与 register 详解

    ansible 定义变量方式与[多层]变量引用,以及 register 详解

    主机规划

    添加用户账号

    说明:

    1、 运维人员使用的登录账号;

    2、 所有的业务都放在 /app/ 下「yun用户的家目录」,避免业务数据乱放;

    3、 该用户也被 ansible 使用,因为几乎所有的生产环境都是禁止 root 远程登录的(因此该 yun 用户也进行了 sudo 提权)。

    复制代码
    1 # 使用一个专门的用户,避免直接使用root用户
    2 # 添加用户、指定家目录并指定用户密码
    3 # sudo提权
    4 # 让其它普通用户可以进入该目录查看信息
    5 useradd -u 1050 -d /app yun && echo '123456' | /usr/bin/passwd --stdin yun
    6 echo "yun  ALL=(ALL)       NOPASSWD: ALL" >>  /etc/sudoers
    7 chmod 755 /app/
    复制代码

    Ansible 配置清单Inventory

    之后文章都是如下主机配置清单

    复制代码
     1 [yun@ansi-manager ansible_info]$ pwd
     2 /app/ansible_info
     3 [yun@ansi-manager ansible_info]$ cat hosts_key 
     4 # 方式1、主机 + 端口 + 密钥
     5 [manageservers]
     6 172.16.1.180:22
     7 
     8 [proxyservers]
     9 172.16.1.18[1:2]:22
    10 
    11 # 方式2:别名 + 主机 + 端口 + 密码
    12 [webservers]
    13 web01 ansible_ssh_host=172.16.1.183 ansible_ssh_port=22
    14 web02 ansible_ssh_host=172.16.1.184 ansible_ssh_port=22
    15 web03 ansible_ssh_host=172.16.1.185 ansible_ssh_port=22
    复制代码

    ansible 定义变量的三种方式

    1、命令行中定义,通过 -e EXTRA_VARS, --extra-vars=EXTRA_VARS 定义

    2、在 playbook 的 yml 文件中定义

    3、在 inventory 清单中定义

    4、变量名可以有下划线,但不能有中横线。

    优先级:命令行定义变量 > playbook定义变量 > inventory 定义变量

    如下内容也是按照优先级从低到高写的,如果是为了测试优先级那么你可以直接按照如下步骤测验。

    测验内容:在不同的位置定义相同的变量,但变量值不同,然后在阿里云镜像源下载不同版本的 zabbix rpm 包。

    地址:https://mirrors.aliyun.com/zabbix/zabbix/

    在 inventory 清单中定义

    有三种定义方式:

    1、直接在 inventory 清单文件中定义变量「了解即可,不推荐使用」

    2、通过 group_vars 定义变量

    3、通过 host_vars 定义变量

    自身内部的优先级:host_vars/主机名【或别名】 定义变量 > group_vars/清单组名 定义变量 > group_vars/all 定义变量> inventory 文件中直接定义变量

    在 inventory 清单文件中定义变量「了解」

    复制代码
     1 [yun@ansi-manager object02]$ pwd
     2 /app/ansible_info/object02
     3 [yun@ansi-manager object02]$ cat ../hosts_key 
     4 # 方式1、主机 + 端口 + 密钥
     5 [manageservers]
     6 172.16.1.180:22
     7 
     8 [proxyservers]
     9 172.16.1.18[1:2]:22
    10 [proxyservers:vars]
    11 zabbix_version=2.2
    12 zabbix_rpm=zabbix-release-2.2-1.el7.noarch.rpm
    13 ### ************ 定义变量如上
    14 
    15 # 方式2:别名 + 主机 + 端口 + 密码
    16 [webservers]
    17 web01 ansible_ssh_host=172.16.1.183 ansible_ssh_port=22
    18 web02 ansible_ssh_host=172.16.1.184 ansible_ssh_port=22
    19 web03 ansible_ssh_host=172.16.1.185 ansible_ssh_port=22
    20 
    21 [yun@ansi-manager object02]$ cat test_vars.yml 
    22 ---
    23 # 下载 zabbix rpm包
    24 - hosts: proxyservers
    25 
    26   tasks:
    27     - name: "download zabbix rpm"
    28       get_url:
    29         url: https://mirrors.aliyun.com/zabbix/zabbix/{{ zabbix_version }}/rhel/7/x86_64/{{ zabbix_rpm }}
    30         dest: /tmp/
    31 
    32 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key --syntax-check test_vars.yml  # 语法检测
    33 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key -C test_vars.yml  # 预执行,测试执行
    34 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key test_vars.yml  # 执行
    复制代码

    然后就可以在目标机器 172.16.1.181、172.16.1.182 查看下载的 zabbix-release-2.2-1.el7.noarch.rpm 包了。

    通过 group_vars 定义变量

    注意事项:

    1、要创建的 group_vars 目录要与 inventory 清单文件在同一个目录,或者与要执行的 playbook 的 yml 文件在同一个目录。

    2、group_vars 目录下的文件名是 inventory 清单文件中的组名。或者文件名为 all「特殊组」,表示对所有机器主机生效。

    在 group_vars/all 定义变量

    复制代码
     1 [yun@ansi-manager object02]$ pwd
     2 /app/ansible_info/object02
     3 [yun@ansi-manager object02]$ ll /app/ansible_info/
     4 total 4
     5 drwxrwxr-x 2 yun yun  17 Oct 15 14:55 group_vars
     6 -rw-rw-r-- 1 yun yun 348 Oct 11 20:36 hosts_key
     7 drwxrwxr-x 2 yun yun  27 Oct 11 20:56 object02 
     8 [yun@ansi-manager object02]$ cat /app/ansible_info/group_vars/all   # all「特殊组」变量文件
     9 zabbix_version: 2.4
    10 zabbix_rpm: zabbix-release-2.4-1.el7.noarch.rpm
    11 
    12 [yun@ansi-manager object02]$ cat test_vars.yml 
    13 ---
    14 # 下载 zabbix rpm包
    15 - hosts: proxyservers
    16 
    17   tasks:
    18     - name: "download zabbix rpm"
    19       get_url:
    20         url: https://mirrors.aliyun.com/zabbix/zabbix/{{ zabbix_version }}/rhel/7/x86_64/{{ zabbix_rpm }}
    21         dest: /tmp/
    22 
    23 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key --syntax-check test_vars.yml  # 语法检测
    24 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key -C test_vars.yml  # 预执行,测试执行
    25 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key test_vars.yml  # 执行
    复制代码

    然后就可以在目标机器 172.16.1.181、172.16.1.182 查看下载的 zabbix-release-2.4-1.el7.noarch.rpm 包了。

    在 group_vars/组 定义变量

    复制代码
     1 [yun@ansi-manager object02]$ pwd
     2 /app/ansible_info/object02
     3 [yun@ansi-manager object02]$ ll /app/ansible_info/
     4 total 4
     5 drwxrwxr-x 2 yun yun  17 Oct 15 14:55 group_vars
     6 -rw-rw-r-- 1 yun yun 348 Oct 11 20:36 hosts_key
     7 drwxrwxr-x 2 yun yun  27 Oct 11 20:56 object02 
     8 [yun@ansi-manager object02]$ cat /app/ansible_info/group_vars/proxyservers   # inventory 清单文件中的组名 变量文件
     9 zabbix_version: 3.0
    10 zabbix_rpm: zabbix-release-3.0-1.el7.noarch.rpm
    11 
    12 [yun@ansi-manager object02]$ cat test_vars.yml 
    13 ---
    14 # 下载 zabbix rpm包
    15 - hosts: proxyservers
    16 
    17   tasks:
    18     - name: "download zabbix rpm"
    19       get_url:
    20         url: https://mirrors.aliyun.com/zabbix/zabbix/{{ zabbix_version }}/rhel/7/x86_64/{{ zabbix_rpm }}
    21         dest: /tmp/
    22 
    23 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key --syntax-check test_vars.yml  # 语法检测
    24 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key -C test_vars.yml  # 预执行,测试执行
    25 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key test_vars.yml  # 执行
    复制代码

    然后就可以在目标机器 172.16.1.181、172.16.1.182 查看下载的 zabbix-release-3.0-1.el7.noarch.rpm 包了。

    通过 host_vars 定义变量

    注意事项:

    1、要创建的 host_vars 目录要与 inventory 清单文件在同一目录,或者与要执行的 playbook 的 yml 文件在同一个目录。

    2、host_vars 目录下的文件名是 inventory 清单文件中的主机名或别名。如果有别名那么文件名为别名

    复制代码
     1 [yun@ansi-manager object02]$ pwd
     2 /app/ansible_info/object02
     3 [yun@ansi-manager object02]$ ll /app/ansible_info/
     4 total 4
     5 -rw-rw-r-- 1 yun yun 348 Oct 11 20:36 hosts_key
     6 drwxrwxr-x 2 yun yun  26 Oct 15 15:50 host_vars
     7 drwxrwxr-x 2 yun yun  27 Oct 11 20:56 object02 
     8 [yun@ansi-manager object02]$ cat /app/ansible_info/host_vars/172.16.1.181    # inventory 清单文件中的主机名或别名 变量文件
     9 zabbix_version: 3.4
    10 zabbix_rpm: zabbix-release-3.4-2.el7.noarch.rpm
    11 
    12 [yun@ansi-manager object02]$ cat test_vars.yml 
    13 ---
    14 # 下载 zabbix rpm包
    15 - hosts: proxyservers
    16 
    17   tasks:
    18     - name: "download zabbix rpm"
    19       get_url:
    20         url: https://mirrors.aliyun.com/zabbix/zabbix/{{ zabbix_version }}/rhel/7/x86_64/{{ zabbix_rpm }}
    21         dest: /tmp/
    22 
    23 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key --syntax-check test_vars.yml  # 语法检测
    24 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key -C test_vars.yml  # 预执行,测试执行
    25 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key test_vars.yml  # 执行
    复制代码

    然后就可以在目标机器 172.16.1.181 查看下载的 zabbix-release-3.4-2.el7.noarch.rpm 包了。

    使用 playbook 定义变量

    使用 playbook 定义变量有两种方式:

    1、直接在要执行的 playbook 文件中定义变量。缺点是:这些变量无法与其他 playbook 共用。

    2、将 playbook 中的变量抽出来,单独一个或多个文件 yml 文件。其他 playbook 文件要使用变量时,可以调用这些变量文件。好处是:可对变量集中管理,降低后期维护成本。「推荐使用」

    自身内部优先级:playbook 引用文件变量 > 直接定义在要执行的 yml 文件中

    直接在 playbook 中定义变量

    变量写在要使用变量的 playbook 文件中。

    复制代码
     1 [yun@ansi-manager object02]$ pwd
     2 /app/ansible_info/object02
     3 [yun@ansi-manager object02]$ ll
     4 total 4
     5 -rw-rw-r-- 1 yun yun 323 Oct 15 16:06 test_vars.yml
     6 [yun@ansi-manager object02]$ cat test_vars.yml 
     7 ---
     8 # 下载 zabbix rpm包
     9 - hosts: proxyservers
    10   # 变量定义
    11   vars:
    12     - zabbix_version: 3.5
    13     - zabbix_rpm: zabbix-release-3.5-1.el7.noarch.rpm
    14 
    15   tasks:
    16     - name: "download zabbix rpm"
    17       get_url:
    18         url: https://mirrors.aliyun.com/zabbix/zabbix/{{ zabbix_version }}/rhel/7/x86_64/{{ zabbix_rpm }}
    19         dest: /tmp/
    20 
    21 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key --syntax-check test_vars.yml  # 语法检测
    22 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key -C test_vars.yml  # 预执行,测试执行
    23 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key test_vars.yml  # 执行
    复制代码

    然后就可以在目标机器 172.16.1.181、172.16.1.182 查看下载的 zabbix-release-3.5-1.el7.noarch.rpm 包了。

    playbook 引用变量文件

    将 playbook 变量抽出来,使用单独的文件进行管理

    复制代码
     1 [yun@ansi-manager object02]$ pwd
     2 /app/ansible_info/object02
     3 [yun@ansi-manager object02]$ ll /app/ansible_info/
     4 total 8
     5 -rw-rw-r-- 1 yun yun 456 Oct 15 15:56 hosts_key
     6 drwxrwxr-x 2 yun yun  27 Oct 15 16:08 object02
     7 -rw-rw-r-- 1 yun yun  69 Oct 15 16:11 playbood_vars.yml
     8 [yun@ansi-manager object02]$ cat /app/ansible_info/playbood_vars.yml  # 单独文件定义的变量
     9 zabbix_version: 4.0
    10 zabbix_rpm: zabbix-release-4.0-1.el7.noarch.rpm
    11 
    12 [yun@ansi-manager object02]$ cat test_vars.yml 
    13 ---
    14 # 下载 zabbix rpm包
    15 - hosts: proxyservers
    16   # 变量引用
    17   vars_files: ../playbood_vars.yml
    18 
    19   # 变量定义
    20   vars:
    21     - zabbix_version: 3.5
    22     - zabbix_rpm: zabbix-release-3.5-1.el7.noarch.rpm
    23 
    24   tasks:
    25     - name: "download zabbix rpm"
    26       get_url:
    27         url: https://mirrors.aliyun.com/zabbix/zabbix/{{ zabbix_version }}/rhel/7/x86_64/{{ zabbix_rpm }}
    28         dest: /tmp/
    29 
    30 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key --syntax-check test_vars.yml  # 语法检测
    31 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key -C test_vars.yml  # 预执行,测试执行
    32 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key test_vars.yml  # 执行
    复制代码

    然后就可以在目标机器 172.16.1.181、172.16.1.182 查看下载的 zabbix-release-4.0-1.el7.noarch.rpm 包了。

    使用命令行定义变量

    优先级别最高,但只是临时使用。

    复制代码
     1 [yun@ansi-manager object02]$ pwd
     2 /app/ansible_info/object02
     3 [yun@ansi-manager object02]$ ll 
     4 total 4
     5 -rw-rw-r-- 1 yun yun 393 Oct 15 16:14 test_vars.yml
     6 [yun@ansi-manager object02]$ cat test_vars.yml 
     7 ---
     8 # 下载 zabbix rpm包
     9 - hosts: proxyservers
    10   # 变量引用
    11   vars_files: ../playbood_vars.yml
    12 
    13   # 变量定义
    14   vars:
    15     - zabbix_version: 3.5
    16     - zabbix_rpm: zabbix-release-3.5-1.el7.noarch.rpm
    17 
    18   tasks:
    19     - name: "download zabbix rpm"
    20       get_url:
    21         url: https://mirrors.aliyun.com/zabbix/zabbix/{{ zabbix_version }}/rhel/7/x86_64/{{ zabbix_rpm }}
    22         dest: /tmp/
    23 
    24 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key -e "zabbix_version=4.1 zabbix_rpm=zabbix-release-4.1-1.el7.noarch.rpm" --syntax-check test_vars.yml  # 语法检测
    25 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key -e "zabbix_version=4.1 zabbix_rpm=zabbix-release-4.1-1.el7.noarch.rpm" -C test_vars.yml  # 预执行,测试执行
    26 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key -e "zabbix_version=4.1 zabbix_rpm=zabbix-release-4.1-1.el7.noarch.rpm" test_vars.yml  # 执行
    复制代码

    然后就可以在目标机器 172.16.1.181、172.16.1.182 查看下载的 zabbix-release-4.1-1.el7.noarch.rpm 包了。

    多层级变量写法与引用

    层级变量的写法与两种引用方式。

    复制代码
     1 [yun@ansi-manager object02]$ pwd
     2 /app/ansible_info/object02
     3 [yun@ansi-manager object02]$ ll /app/ansible_info/
     4 total 12
     5 -rw-rw-r-- 1 yun yun 456 Oct 15 15:56 hosts_key
     6 drwxrwxr-x 2 yun yun  27 Oct 15 16:14 object02
     7 -rw-rw-r-- 1 yun yun  76 Oct 15 16:26 playbood_vars_mult.yml
     8 [yun@ansi-manager object02]$ cat /app/ansible_info/playbood_vars_mult.yml 
     9 # 多层级变量书写
    10 zabbix_rpm_info:
    11   version: 4.2
    12   rpm: zabbix-release-4.2-1.el7.noarch.rpm
    13 
    14 [yun@ansi-manager object02]$ cat test_vars_mult.yml  # 具体的 playbook 信息
    15 ---
    16 # 下载 zabbix rpm包
    17 - hosts: proxyservers
    18   # 变量引用
    19   vars_files: ../playbood_vars_mult.yml
    20 
    21   tasks:
    22     - name: "download zabbix rpm"
    23       get_url:
    24         # 下面写了两种方式引用变量,推荐使用后一种引用方式
    25         url: https://mirrors.aliyun.com/zabbix/zabbix/{{ zabbix_rpm_info.version }}/rhel/7/x86_64/{{ zabbix_rpm_info['rpm'] }}
    26         dest: /tmp/
    27 
    28 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key --syntax-check test_vars_mult.yml  # 语法检测
    29 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key -C test_vars_mult.yml  # 预执行,测试执行
    30 [yun@ansi-manager object02]$ ansible-playbook -b -i ../hosts_key test_vars_mult.yml  # 执行
    复制代码

    然后就可以在目标机器 172.16.1.181、172.16.1.182 查看下载的 zabbix-release-4.2-1.el7.noarch.rpm 包了。

    register 注册变量

    如何使用 register 注册变量

    复制代码
     1 [yun@ansi-manager ansible_info]$ pwd
     2 /app/ansible_info
     3 [yun@ansi-manager ansible_info]$ ll
     4 total 24
     5 -rw-rw-r-- 1 yun yun  483 Aug 18 09:12 hosts_key
     6 -rw-rw-r-- 1 yun yun  245 Aug 18 21:55 test_debug_register.yml
     7 [yun@ansi-manager ansible_info]$ cat test_debug_register.yml 
     8 ---
     9 # 如何使用 debug 模块与 register 变量
    10 - hosts: proxyservers
    11 
    12   tasks:
    13     - name: "get host port info"
    14       shell: netstat -lntp
    15       register: host_port
    16 
    17     - name: "print host port"
    18       debug:
    19         #msg: "{{ host_port }}"   # 输出全部信息
    20         #msg: "{{ host_port.cmd }}"   # 引用方式一
    21         msg: "{{ host_port['stdout_lines'] }}"  # 引用方式二
    22 
    23 [yun@ansi-manager ansible_info]$ ansible-playbook -b -i ./hosts_key test_debug_register.yml  # 执行
    复制代码

    第一个 task 中,使用了 register 注册变量,名为 host_port ;当 shell 模块执行完毕后,会将数据放到该变量中。

    第二给 task 中,使用了 debug 模块,并从 host_port 中获取数据。

  • 相关阅读:
    php 中的 Output Control 函数
    web安全知识
    php写一个web五子棋
    实现一个web服务器, 支持php
    字节序
    TinyHTTPd源码分析
    linux 管道通信
    linux网络编程
    微信公众号开发-静默授权实现消息推送(微服务方式)
    初学 Nginx
  • 原文地址:https://www.cnblogs.com/shetao/p/14338672.html
Copyright © 2011-2022 走看看