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. istio部署

    Istio的部署介绍 目录 Istio的部署介绍 部署模型 集群模式 单集群 多集群 网络模型 单网络 多网络 控制面模型 身份和信任模型 网格中的信任 网格之间的信任 网格模型 单网格 多网格 租户 ...

  2. 安装和配置SQL

    安装和配置SQL 在终端输入 npm i mysql命令安装SQL(加上-g全局安装) 配置SQL // 1.导入mysql模块 const mysql = require("mysql&q ...

  3. 跟着尚硅谷系统学习Docker-【day04】

    day04-20200716   p18.docker容器数据卷   docker容器中的数据,做持久化. 容器关闭以后容器内的数据就没有了. 保存到数据库或者服务器宿主机里面.   作用:容器间可以 ...

  4. Mysql数据库扩展

    安装跟卸载 Mysql安装 下载Mysql源安装包 1   wget http://dev.mysql.com/get/mysql57-community-release-el7-8.noarch.r ...

  5. Ubuntu修改默认Python版本,你了解多少~

    目录 1 查看Python版本 1.1 查看装有哪些版本 1.2 查看默认版本 2 修改Python默认版本 2.1 基于文件修改 2.2 基于软链接修改 1 查看Python版本 1.1 查看装有哪 ...

  6. Popular Cows(POJ 2186)

    原题如下: Popular Cows Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 40746   Accepted: 16 ...

  7. 自定义AQS独占模式下的同步器来实现独享锁

    自定义AQS独占模式下的同步器来实现独享锁 /** * 自定义AQS独占模式下的同步器来实现独享锁 */ public class Mutex implements Lock, java.io.Ser ...

  8. git注册到git管理远程仓库

    注册: ① 注册github网站:地址:https://github.com/,其中sign up 是注册,sign in是登录 (如果是用QQ邮箱的话,如果觉得收不到邮箱,可能是在垃圾箱哦) ② 之 ...

  9. 将HBase中的表加载到hive中

    两种方式加载hbase中的表到hive中,一是hive创建外部表关联hbase表数据,二是hive创建普通表将hbase的数据加载到本地 1. 创建外部表 hbase中已经有了一个test表,内容如下 ...

  10. 【译】Visual Studio 2019 的 Local Process with Kubernetes

    今天,我们自豪地宣布 Local Process with Kubernetes 的预览版已加入到 Visual Studio 2019 16.7 Preview 2 中.  Local Proces ...