《Linux运维实战:ansible中的变量定义及以及变量的优先级》

news2025/1/23 17:02:24

一、配置文件优先级

Ansible配置以ini格式存储配置数据,在Ansible中⼏乎所有配置都可以通过Ansible的Playbook或环境变量来重新赋值。在运⾏Ansible命令时,命令将会按照以下顺序查找配置⽂件。

# ⾸先,Ansible命令会检查环境变量,及这个环境变量指向的配置⽂件。 例如:export ANSIBLE_CONFIG=/PATH/ansible.cfg
# 其次,将会检查当前⽬录下的ansible.cfg配置⽂件
# 再次,将会检查当前⽤户home⽬录下的ansible.cfg配置⽂件
# 最后,将会检查在⽤软件包管理⼯具安装Ansible时⾃动产⽣的配置⽂件

二、变量命名

变量的名称必须以字母开头,并且只能包含字母、数字和下划线。


三、变量优先级

* extra vars (-e in the command line) always win
* then comes connection variables defined in inventory (ansible_ssh_user, etc)
* then comes "most everything else" (command line switches, vars in play, included vars, role vars, etc)
* then comes the rest of the variables defined in inventory
* then comes facts discovered about a system
* then "role defaults", which are the most "defaulty" and lose in priority to everything.

* extra vars (在命令行中使用 -e)优先级最高
* 然后是在inventory中定义的连接变量(比如ansible_ssh_user)
* 接着是大多数的其它变量(命令行转换,play中的变量,included的变量,role中的变量等)
* 然后是在inventory定义的其它变量
* 然后是由系统发现的facts
* 然后是 "role默认变量", 这个是最默认的值,很容易丧失优先权

四、变量分类

可以在Ansible项目中的多个位置定义变量。不过,这些变量可简化为三个范围级别:

# 全局范围:从命令行或Ansible的配置文件设置的变量
# Play范围:在play和相关结构中设置的变量
# 主机范围:由清单、事实收集或注册的任务,在主机组和个别主机上设置的变量

4.1、playbook中的变量

可以在playbook剧本任务中定义变量,主要有两种方式。一种是在将变量放在playbook开头的vars块中,另外一种是在外部文件中定义playbook变量。

示例一:在playbook开头的vars块中定义变量,如下所示:

- hosts: 
  - all
  remote_user: root
  roles:
  - allinone1
  vars:
    role: master
    service: mysql

示例二:在外部文件中定义playbook变量,如下所示:

- hosts: all
  remote_user: root
  vars:
    favcolor: blue
  vars_files:
    - /opt/external_vars.yml

说明:声明了变量后,可以在任务中使用这些变量。若要引用变量,可以将变量名放在双大括号内。在任务执行时,Ansible会将变量替换为其值。切记- name中定义任务的名称,不能以变量开头,即{{ }}开头。
在这里插入图片描述


4.2、主机变量和组变量

应用于主机的清单文件分为两种,一种是主机变量,应用于特定主机,另外一种是主机组变量,应用于一个主机组或一组主机组中的所有主机。主机变量优先于组变量, 但playbook中定义的变量的优先级比这两者更高。定义主机变量和组变量有两种方式,一种是直接在主机清单hosts文件中定义,一种是创建host_vars和group_vars目录。

1、在主机清单hosts文件中定义变量

示例一:主机变量
在这里插入图片描述

示例二:主机组变量
在这里插入图片描述

2、在host_vars和group_vars目录中创建定义变量文件

注意:主机和主机组的目录名必须是host_vars和group_vars,且与清单文件所在目录相同。hosts_vars和group_vars对应的变量文件名称必须于清单文件中定义的主机和主机组必须保持一致。

在这里插入图片描述


4.3、从命令行覆盖变量

从命令行中传递变量有两种方式,一种为直接定义变量,一种为指定一个变量文件。

示例一:命令行中直接定义变量,如下所示:

# 示例一:
# ansible-playbook -i hosts -e "package=apache2" -t buid mysql-cluster.yml

示例二:命令行中指定变量文件,如下所示:

# 示例二
# ansible-playbook -i hosts -e @config.yml  -t check mysql-cluster.yml

4.4、使用迭代数组定义变量

除了将同一元素相关的配置数据(软件包列表、服务列表和用户列表等)分配到多个变量外,也可以使用数组。这种做法的一个好处在于,数组是可以浏览的。

例如,假设有如下代码片段:

在这里插入图片描述

可以改写成mysql的数组
在这里插入图片描述

可以使用以下变量来访问用户数据

mysql.work_dir
mysql.data_dir
mysql.root_password
mysql.master.host
mysql.master.port

由于变量被定义为Python字典,因此可以使用替代语法,使用中括号表示法有助于避免冲突和错误:

mysql.['master'].['host']
mysql.['master'].['port']

注意:以上两种语法都有效,但为了方便故障排除,建议在任何给定Ansible项目的所有文件中一致地采用一种语法,不要混用。


4.5、使用register注册变量

可以使用register语句捕获命令输出。输出保存在一个临时变量中,然后在playbook中可用于调试用途或者达成其他目的。
在这里插入图片描述

总结:当我们给被管理节点安装了某个服务,不晓得有没有安装正确的情况下,可以使用register变量注册的方法,来返回被管理节点的服务信息。

- hosts: dbserver
  tasks:
    - name: install httpd server
      yum: name=httpd state=present

    - name: service httpd server
      service: name=httpd state=started

    - name: check httpd server
      shell: ps aux | grep httpd
      register: check_httpd

    - name: output variables
      debug: msg="{{ check_httpd }}"

如下图所示:
在这里插入图片描述


4.6、facts事实变量

《Ansible变量篇:ansible中事实变量facts》


4.6、魔法变量

《Ansible变量篇:ansible中魔法变量》


总结:整理不易,如果对你有帮助,可否点赞关注一下?

更多详细内容请参考:《Linux运维篇:Linux系统运维指南》

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/398868.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【node : 无法将“node”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。 最全面有效的解决方案】

执行nodejs文件错误: 这个错误提示通常是由于你的系统无法识别 "node" 命令,可能是由于你没有正确地安装或配置 Node.js 环境变量。 问题描述 ​​​​​​​​​​​​​​ 原因分析: 可能原因包括: 1.Node.js未正确安…

JVM堆与堆调优以及出现OOM如何排查

调优的位置——堆 Heap,一个JVM只有一个堆内存,堆内存的大小是可以调节的。 类加载器读取了类文件后,一般会把什么东西放到堆中?类,方法,常量,变量~,保存我们所有引用类型的真实对象; 堆内存中…

【Linux修炼】15.进程间通信

每一个不曾起舞的日子,都是对生命的辜负。 进程间通信进程间通信一.理解进程间通信1.1 什么是通信1.2 为什么要有通信1.3 如何进行进程间通信二.管道2.1 匿名管道2.2 匿名管道编码部分2.3 管道的特点2.4 如何理解命令行中的管道2.5 进程控制多个子进程三.命名管道3.…

openEuler用户软件仓(EUR)介绍

什么是 EUR EUR(openEuler User Repo)是openEuler社区针对开发者推出的个人软件包托管平台,目的在于为开发者提供一个易用的软件包分发平台。 链接:https://eur.openeuler.openatom.cn/ 为什么我们需要 EUR 在操作系统的世界,软件包是一等…

数据库基本功之复杂查询-多表连接

1. 简单查询的解析方法 全表扫描:指针从第一条记录开始,依次逐行处理,直到最后一条记录结束;横向选择纵向投影结果集 2. 多表连接 交叉连接(笛卡尔积) 非等值连接 等值连接 内连 外连接(内连的扩展,左外,右外,全连接) 自连接 自然连接(内连,隐含连接条件,自动匹配连接字段) …

以创作之名致敬女性开发者

作者简介:一名云计算网络运维人员、每天分享网络与运维的技术与干货。 座右铭:低头赶路,敬事如仪 个人主页:网络豆的主页​​​​​​ 前言 在昨天的2023年3月8日,是咱们女性朋友的节日妇女节,本章将会…

腾讯云GPU游戏服务器/云主机租用配置价格表

用于游戏业务的服务器和普通云服务器和主机空间是不同的,游戏服务器对于硬件的配置、网络带宽有更大的要求,一般游戏服务器根据不同的配置和适用场景会有十几元一小时到几十元一小时,而且可以根据不同的按量计费。而普通的云服务器可能需要几…

Linux程序替换

Linux程序替换创建子进程的目的?程序替换如何实现程序替换?什么是程序替换?先见一见单进程版本的程序替换程序替换原理多进程版本的程序替换execl函数组简易版Shell创建子进程的目的? 目的:为了帮助父进程完成一些特定的任务&…

网络实时变更监控

网络变更监控 未经授权的配置变更会严重破坏业务连续性,这就是为什么检测和跟踪变更是网络管理员的一项关键任务。虽然可以手动跟踪变更,但此方法往往很耗时,并且经常会导致人为错误,例如在跟踪时遗漏了关键网络设备的配置。 要解…

JavaEE简单示例——Spring的控制反转

简单介绍: 在之前的入门程序中,我们简单的介绍了关于Spring框架中的控制反转的概念,这次我们就来详细的介绍和体验一下Spring中的控制反转的理论和实操。 使用方法: 控制反转(IoC)是面向对象编程中的一个…

HTML5 和 CSS3 的新特性

目标能够说出 3~5 个 HTML5 新增布局和表单标签能够说出 CSS3 的新增特性有哪些HTML5新特性概述HTML5 的新增特性主要是针对于以前的不足,增加了一些新的标签、新的表单和新的表单属性等。 这些新特性都有兼容性问题,基本是 IE9 以上版本的浏览器才支持&…

CentOS 部署rocketmq集群

一、rocketmq 概览 1.rocketmq简介 rocketmq是一个队列模型的消息中间件,具有高性能、高可靠、高实时、分布式特点。能够保证严格的消息顺序,提供丰富的消息拉取模式,高效的订阅者水平扩展能力,实时的消息订阅机制。 2.rocketmq结…

项目四:使用路由交换机构建园区网-任务三:配置路由交换机并进行通信测试

配置路由交换机并通信测试1、在RS-1上创建VLAN并配置Trunk接口2、测试通信结果3、配置RS-1的三层路由接口(SVI)1、在RS-1上创建VLAN并配置Trunk接口 进入系统视图,关闭信息中心,重命名为RS-1 system-view undo info-center enab…

day48第九章动态规划(二刷)

今日任务 198.打家劫舍213.打家劫舍II337.打家劫舍III 今天就是打家劫舍的一天,这个系列不算难,大家可以一口气拿下。 198.打家劫舍 题目链接: https://leetcode.cn/problems/house-robber/description/ 题目描述: 你是一个…

synchronized轻量级锁优化

synchronized优化轻量级锁 使用场景 如果一个对象虽然有多个线程访问,但多线程访问时间是错开的,也就是没有竞争,那么可以使用轻量级锁优化; 原理 1、每个线程的栈帧中有锁记录 包括:记录锁对象的地址Object refer…

一次有效沟通的组成

犹记得之前看过一篇文章当中写道 『Tech Lead 作为开发团队的技术负责人,对内对外都起到至关重要的作用。Tech Lead 对外是团队技术能力的展现窗口,需要将团队的技术能力呈现给客户或业务团队。对内他需要和各个角色紧密协作,给非技术角色技术…

50年前的程序员女神,用代码把人类送上月球

1969年7月20日,经过4天飞行的阿波罗11号终于来到了最关键的时刻:降落到月球表面。就在这个时候,飞船计算机突然开始闪烁报警。全球6亿人在观看电视直播,NASA飞行控制中心的气氛让人窒息。人类的首次登月计划面临着艰难的抉择&…

d3绘图笔记

D3绘图笔记 安装与引用 npm install d3 --save-dev import * as d3 from d3; 选择器 d3.select() 可直接接元素名,也可以接属性与类 添加svg标签 this.d3 d3.select(.myd3) let svg this.d3.append("svg") // 添加svg并设置好高宽 .attr("wid…

<Linux>system v通信

前言😃😃😃进程间通信的方式管道 - Linux原生提供SystemV - 多线程单机通信posix - 多线程网络通信这里我们主要是介绍一下SystemV通信方式一、SystemV原理首先我们需要知道通信的本质:多个进程能看到同一个资源,即内存…

如何使用码匠连接 CouchDB

目录 在码匠中集成 CouchDB 在码匠中使用 CouchDB 关于码匠 CouchDB 是一种开源的 NoSQL 数据库服务,它使用基于文档的数据模型来存储数据。CouchDB 的数据源提供了高度可扩展性、高可用性和分布式性质。它支持跨多个节点的数据同步和复制,可以在多个…