1. ansible-playbook变量定义与使用

  • 命令行
  • 在Inventory中定义
  • 在Playbook中定义
  • 在Role中定义
  • 注册变量(register)
  • 系统信息变量(facts)

2. 在命令行中定义变量
  2.1) 案例编写playbook中定义,变量命令行传参

 1 [root@test-1 bin]# vim veriable.yaml
2 [root@test-1 bin]# cat veriable.yaml
3 ---
4 - hosts: web1
5 gather_facts: no
6 remote_user: root
7
8
9 tasks:
10 - name: test var
11 debug: msg="{{work_dir}}"

2.2) 执行playbook变量命令传参

 1 [root@test-1 bin]# ansible-playbook veriable.yaml -e work_dir=/usr/local
2
3 PLAY [web1] ******************************************************************************************************************************************************************************************************************************************************************
4
5 TASK [test var] **************************************************************************************************************************************************************************************************************************************************************
6 ok: [192.168.200.132] => {
7 "msg": "/usr/local"
8 }
9 ok: [192.168.200.133] => {
10 "msg": "/usr/local"
11 }
12
13 PLAY RECAP *******************************************************************************************************************************************************************************************************************************************************************
14 192.168.200.132 : ok=1 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
15 192.168.200.133 : ok=1 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0

3. 在inventory中定义变量
    是在通过hosts文件里定义变量

1 [WebServer]
2 app[01:03].imzcy.cn
3
4
5 [DB]
6 db-[a:c].imzcy.com
7
8
9 192.168.109.[131:133]

4. 在Playbook中定义变量
  4.1)编写Playbook定义变量

 1 [root@test-1 bin]# vim playbook.yaml
2 [root@test-1 bin]# cat playbook.yaml
3 ---
4 - hosts: web1
5 gather_facts: no
6 remote_user: root
7 vars:
8 - work_dir: /usr/local
9 - nginx_version: 1.15
10
11 tasks:
12 - name: install nginx
13 debug: msg="{{work_dir}}/nginx/{{nginx_version}}"

4.2) 执行playbook配置文件语法检测

1 [root@test-1 bin]# ansible-playbook --syntax-check playbook.yaml
2
3 playbook: playbook.yaml

4.3) 执行playbook变量文件传参

 1 [root@test-1 bin]# ansible-playbook  playbook.yaml
2
3 PLAY [web1] ************************************************************************************************************************************
4
5 TASK [install nginx] ***************************************************************************************************************************
6 ok: [192.168.200.132] => {
7 "msg": "/usr/local/nginx/1.15"
8 }
9 ok: [192.168.200.133] => {
10 "msg": "/usr/local/nginx/1.15"
11 }
12
13 PLAY RECAP *************************************************************************************************************************************
14 192.168.200.132 : ok=1 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
15 192.168.200.133 : ok=1 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0

5. 在Role中定义

1 [root@test-1 vars]# vim /ansible/roles/nginx/vars/main.yaml
2 [root@test-1 vars]# cat /ansible/roles/nginx/vars/main.yaml
3 ---
4 #nginx
5 nginx_version: 1.16.1
6 http_port: 80
7 server_name: test-www.scajy.cn

6. 注册变量(register)
  6.1)编写register注册变量

 1 [root@test-1 bin]# vim register.yaml
2 [root@test-1 bin]# cat register.yaml
3 ---
4 - hosts: web1
5 gather_facts: no
6 remote_user: root
7 vars:
8 - work_dir: /usr/local
9 - nginx_version: 1.15.1
10
11 tasks:
12 - name: register var
13 command: date +"%F_%T"
14 register: datetime
15
16 - name: touch file
17 file:
18 dest: /tmp/r_{{datetime.stdout}}
19 state: touch

6.2) 检查语法是否错误

1 [root@test-1 bin]# ansible-playbook --syntax-check register.yaml
2
3 playbook: register.yaml

6.3) 执行register配置文件

 1 [root@test-1 bin]# ansible-playbook register.yaml
2
3 PLAY [web1] ************************************************************************************************************************************
4
5 TASK [register var] ****************************************************************************************************************************
6 changed: [192.168.200.133]
7 changed: [192.168.200.132]
8
9 TASK [touch file] ******************************************************************************************************************************
10 changed: [192.168.200.133]
11 changed: [192.168.200.132]
12
13 PLAY RECAP *************************************************************************************************************************************
14 192.168.200.132 : ok=2 changed=2 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
15 192.168.200.133 : ok=2 changed=2 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0

6.4) 验证tmp下是否创建了文件

 1 [root@test-1 bin]# ansible web1 -m shell -a "ls -a  /tmp |grep r_*"
2 192.168.200.132 | CHANGED | rc=0 >>
3 apache-tomcat-8.5.38.tar.gz
4 hsperfdata_root
5 r_2019-08-25_11:04:53
6
7
8 192.168.200.133 | CHANGED | rc=0 >>
9 apache-tomcat-8.5.38.tar.gz
10 hsperfdata_root
11 r_2019-08-25_11:04:53

7. 系统信息变量(facts)

1 ---
2 - hosts:webservers
3 tasks:
4 - debug:
5 msg: {{group_names}} #打印ansible的host组
6 - debug:
7 msg: {{inventory_hostname}} #打印详细的host主机
8 - debug:
9 msg: {{ansible_hostname}} #配合gather_facts: yes 开启收集系统信息

ansible-playbook定义变量与使用的更多相关文章

  1. Ansible Playbook 使用变量

    如何在 Playbook 中定义并使用变量: vars: - user: "test" # 定义变量 tasks: - name: create user user: name=& ...

  2. ansible中定义变量的若干方法

    Ansible支持十几种定义变量的方式 根据优先级排序的定义方式: Inventory变量 Host Facts变量 Playbook变量 Playbook提示变量 变量文件 命令行变量 1.Inve ...

  3. Ansible Playbook 变量与 register 详解

    ansible 定义变量方式与[多层]变量引用,以及 register 详解 主机规划 添加用户账号 说明: 1. 运维人员使用的登录账号: 2. 所有的业务都放在 /app/ 下「yun用户的家目录 ...

  4. ansible playbook 变量

    变量优先级 在命令中定义的变量(-e参数指定的) 在inventory中定义的变量(ansible_ssh_user等) 其他变量(role中.play中) 系统通过father_facts定义的变量 ...

  5. 二、Ansible中playbook的变量

    先看看debug模块的使用: msg:输出调试信息 var:将某个任务执行的输出作为变量传给debug模块,debug模块将其打印输出 verbosity:debug的任务级别   1:在playbo ...

  6. Ansible中playbook的变量

    转自:http://www.cnblogs.com/lemon-le/p/6862788.html 先看看debug模块的使用: msg:输出调试信息 var:将某个任务执行的输出作为变量传给debu ...

  7. Ansible playbook 批量修改服务器密码 先普通后root用户

    fsckzy   Ansible playbook 批量修改服务器密码 客户的需求:修改所有服务器密码,密码规则为Rfv5%+主机名后3位 背景:服务器有CentOS6.7,SuSE9.10.11,r ...

  8. 写Ansible playbook添加zabbix被监控的对象

    本主题达到的效果是能通过编写Ansible Playbook,创建zabbix主机组,把被监控的对象加入到zabbix监控系统中,同时链接到对象的模板. 1.准备工作 在zabbix服务器上面,我们需 ...

  9. Ansible Playbook Variables

    虽然自动化存在使得更容易使事情重复,但所有的系统可能不完全一样. 在某些系统上,您可能需要设置一些与其他操作略有不同的行为或配置. 此外,一些观察到的远程系统的行为或状态可能需要影响如何配置这些系统. ...

随机推荐

  1. 一键部署k8s

    本人学习安装kubernetes时,顺便整理了安装脚本,可以通过执行一个脚本,自动二进制安装好1台master+2台node的k8环境.方便需要学习k8s的同学. 百度网盘:https://pan.b ...

  2. 下载安装gradle

    1.登录官网:www.gradle.org,进入到下图的界面: 2.点击Install Gradle,跳转到下一个界面后: 3.下载 4.下载成功后,解压到任意位置,将路径添加到path路径下,选择我 ...

  3. 8.ffmpeg-基础常用知识

    1.封装格式MPEG-4其中 MPEG-1 和 MPEG-2 是采用相同原理为基础的预测编码.变换编码. 熵编码及运动补偿等第一代数据压缩编码技术:MPEG-4(ISO/IEC 14496)则是基于第 ...

  4. My97DatePicker时间控件使用方法

    引入css及js <asp:TextBox ID="tb_startTime" runat="server" CssClass="Wdate&q ...

  5. Kubernetes笔记(五):了解Pod(容器组)

    Kubernetes 中, 容器总是以 Pod(容器组)的方式进行调度与运行.因此对 Pod 的理解与掌握是学习 Kubernetes 的基础. 理解 Pod Pod(容器组)是 Kubernetes ...

  6. [LeetCode]1114. 按序打印(并发)

    ####题目 我们提供了一个类: public class Foo {   public void one() { print("one"); }   public void tw ...

  7. [算法]求满足要求的进制(辗转相除(欧几里得算法),求最大公约数gcd)

    题目 3在十进制下满足若各位和能被3整除,则该数能被3整除. 5在十六进制下也满足此规律. 给定数字k,求多少进制(1e18进制范围内)下能满足此规律,找出一个即可,无则输出-1. 题解 写写画画能找 ...

  8. 二、Git安装--Windows

    Git安装配置 在使用Git前我们需要先安装 Git.Git 目前支持 Linux/Unix.Solaris.Mac和 Windows 平台上运行. Git 各平台安装包下载地址为:http://gi ...

  9. 操作系统(AIX)双因素身份认证解决方案-中科恒伦CKEY DAS

      一.场景分析 操作系统是管理计算机硬件与软件资源的计算机程序,用于工作中的进程管理.存储管理.设备管理.文件管理.作业管理等,十分重要,安全等级极高! 二.问题分析 1.密码设置简单,非常容易被撞 ...

  10. 超详细的 Vagrant 上手指南

    搭建 Linux 虚拟机,别再用 VirtualBox 从 .iso 文件安装了. 概述 2020 年了,也许你已经习惯了 docker,习惯了在 XX 云上快速创建云主机,但是如果你想在个人电脑上安 ...