ansible事实详解

Ansible 事实是 Ansible 在执行任务前,自动从受控节点收集的系统信息集合,这些信息会以变量形式存储,能直接用于区分不同节点的配置逻辑,实现自动化任务的差异化执行。

  1. 核心收集的信息类型

• 基础主机信息:包含主机名、系统发行版(如 CentOS、Ubuntu)、发行版具体版本、系统家族(如 RedHat 家族、Debian 家族)、内核版本、系统架构(如 x86_64、arm64)。

• 硬件资源信息:包含 CPU 总核心数、总内存大小、可用内存大小、磁盘分区与挂载点详情、主机的网卡列表。

• 网络配置信息:包含各网卡对应的 IPv4 地址、主机的所有 IPv4 地址列表、网卡 MAC 地址、DNS 服务器地址。

• 说明:默认事实不包含已安装软件包和服务运行状态,这类信息需要通过专用模块主动查询。

  1. 查看事实的方法

• 命令行查看

使用 Ansible 内置的 setup 模块,可查看单个主机或主机组的所有事实,也能通过过滤关键词,只查看特定类别的信息,比如只看内存相关的事实。

• 在任务执行过程中查看

在自动化任务流程里,可通过调试功能输出指定的事实变量,快速验证受控节点的对应信息。

  1. 事实收集的开关与自定义

• 关闭默认收集

如果执行的自动化任务不需要用到任何事实信息,可关闭自动收集功能,以此提升任务的执行效率。

• 自定义本地事实

除了 Ansible 自动收集的默认事实,还能在受控节点的指定目录下,创建以 .fact 为后缀的文件,写入自定义的信息,Ansible 会自动加载这些内容并作为事实变量,供任务调用。

  1. 典型应用场景

• 差异化系统配置:根据受控节点的系统家族,选择对应的包管理器进行软件安装,比如 RedHat 家族用 yum,Debian 家族用 apt。

• 硬件资源校验:在部署服务前,检查受控节点的内存、CPU 等硬件资源是否满足服务运行的最低要求,不满足则终止任务并提示。

相关推荐
武子康5 分钟前
调查研究-167 Docker Compose 详解:从单容器到多服务编排的工程化入口
运维·docker·云原生·容器·kubernetes·k8s·docker-compose
heimeiyingwang31 分钟前
【架构实战】分布式会话:从Session到JWT的演进
微服务·云原生·架构
DolphinScheduler社区4 小时前
Apache DolphinScheduler 3.4.2 正式发布!新增 Amazon EMR Serverless 插件,增强监控与补数据能力
大数据·云原生·serverless·apache·海豚调度·版本发版
heimeiyingwang5 小时前
【架构实战】注册中心选型:Nacos vs Eureka vs Consul
微服务·云原生·架构
java_cj5 小时前
阅读 k8s 源码的准备工作
云原生·容器·kubernetes
鹤落晴春19 小时前
【K8s】Pod调度、configMaps
云原生·容器·kubernetes
张忠琳19 小时前
【runc 1.4.2】(Part 2)runc 1.4.2 超深度分析 — CLI层:main.go、命令文件、runner、信号处理、TTY
云原生·kubernetes·runc
阿里云云原生21 小时前
AI 提效是“假象”还是“红利”?用 LoongSuite + SLS 构建组织级 AI 编码度量看板
云原生
Java识堂1 天前
如何对微服务进行拆分?
微服务·云原生·架构
Plastic garden1 天前
K8s知识(3) Pod亲和性,调度
云原生·容器·kubernetes