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 等硬件资源是否满足服务运行的最低要求,不满足则终止任务并提示。

相关推荐
阿里云云原生1 天前
Higress v2.2.3 发布:正式入驻 CNCF Sandbox,AI Gateway 与 Ingress 迁移能力双向加固
云原生
阿里云云原生2 天前
香港站【企业 AI Agent 工程化实战专场】来啦,邀您7月9日见!
云原生·agent
阿里云云原生2 天前
研发域与运维域的“数字握手”:通过 Agentic Skills 实现 DevOps 全链路自动化
云原生
阿里云云原生6 天前
AI 开发新常态:当 Cursor、Claude、Codex 并行,如何统一管理散落的 Skill 资产?
云原生·ai编程
探索云原生6 天前
K8s 1.36 这个 GA 特性,把 initContainer 拉模型的 hack 干掉了
ai·云原生·kubernetes
Java之美6 天前
从edge-trigger到level-trigger,谈谈 Kubernetes controller 的开发范式
云原生
阿里云云原生7 天前
深度解构:当 Append-only 的 SLS 遇上 Update/Delete,是如何实现设计权衡的?
云原生
Java之美7 天前
一次k8s升级引发的DevicePlugin注册失败
云原生·kubernetes
秋播7 天前
nerdctl推送rancher本地镜像到harbor
云原生
阿里云云原生8 天前
告别冗长链路!Kafka × Table Bucket 实现开放表格式零 ETL 实时入湖
云原生·kafka