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

相关推荐
Kendra9196 小时前
Kubernetes 常用命令
云原生·容器·kubernetes
没有bug.的程序员13 小时前
Service Mesh 与 Spring Cloud 共存方案:双体系治理、平滑迁移与风险控制实战指南
云原生·springcloud·流量治理·混合架构·servicemesh·微服务迁移·技术演进
一只鱼丸yo13 小时前
从单体到微服务:一次真实迁移实战
微服务·云原生·架构
2501_9399090515 小时前
k8s基础与安装部署
云原生·容器·kubernetes
掘金-我是哪吒18 小时前
Kafka配套的Zookeeper启动脚本
分布式·zookeeper·云原生·kafka
IT 行者18 小时前
微服务架构选型指南:中小型软件公司的理性思考
微服务·云原生·架构
Chan1619 小时前
微服务 - Higress网关
java·spring boot·微服务·云原生·面试·架构·intellij-idea
没有bug.的程序员19 小时前
Serverless 架构深度解析:FaaS/BaaS、冷启动困境与场景适配指南
云原生·架构·serverless·架构设计·冷启动·baas·faas
一条咸鱼_SaltyFish20 小时前
[Day13] 微服务架构下的共享基础库设计:contract-common 模块实践
开发语言·人工智能·微服务·云原生·架构·ai编程
原神启动121 小时前
K8S(七)—— Kubernetes Pod 基础概念与实战配置
云原生·容器·kubernetes