Linux使用Ansible做配置管理_批量执行与自动化部署核心方法【教程】

1次阅读

ansible 是基于 YAML、无代理、通过 ssh 实现的声明式自动化工具,核心为“定义状态”与“操作可复现”。需控制节点装 Ansible 和 python,目标主机开通 SSH 并配置免密登录;用 inventory 分组管理主机;Ad-hoc 命令支持秒级批量操作;Playbook 实现可复用编排,配合 tags、handlers、vault 等保障可维护性与安全性。

Linux使用Ansible做配置管理_批量执行与自动化部署核心方法【教程】

Ansible 是 linux 环境下轻量、无代理、基于 YAML 的配置管理与自动化部署利器。它不依赖客户端安装,靠 SSH 连接目标主机,用 Playbook 描述状态,用 Ad-hoc 命令快速批量执行——核心就两点:声明式定义“要什么”,而不是“怎么做”,以及所有操作可复现、可版本化、可审计

一、环境准备:控制节点 + 目标主机免密 SSH

Ansible 控制机(你本机或跳板机)需装 Python 3 和 ansible;目标主机只需开通 SSH、有 Python(通常默认自带)。关键一步是打通免密登录:

  • 在控制节点运行 ssh-keygen -t rsa 生成密钥对
  • ssh-copy-id user@host 把公钥推到每台目标主机
  • 测试连通性:ansible all -m ping -i inventory.ini(inventory.ini 是主机清单文件)

二、主机清单(Inventory)按角色分组管理

Inventory 不只是 IP 列表,更是逻辑组织的起点。支持 INI 或 YAML 格式,推荐用 inventory.ini

  • [web] 下写 nginx/HTTPD 主机,[db]数据库节点
  • 支持变量内联:db01 ansible_host=192.168.1.10 ansible_user=ops
  • 可嵌套分组:[prod:children] 包含 web 和 db,方便一键操作整套生产环境

三、Ad-hoc 命令:秒级批量执行日常任务

不用写脚本,一条命令完成日志清理、服务重启、包更新等高频操作:

Linux使用Ansible做配置管理_批量执行与自动化部署核心方法【教程】

ListenLeap

ai辅助通过播客学英语

Linux使用Ansible做配置管理_批量执行与自动化部署核心方法【教程】 217

查看详情 Linux使用Ansible做配置管理_批量执行与自动化部署核心方法【教程】

  • 查所有主机磁盘使用:ansible prod -m shell -a “df -h”
  • 批量重启 Nginx:ansible web -m service -a “name=nginx state=restarted”
  • 推送文件并设权限:ansible db -m copy -a “src=/tmp/my.cnf dest=/etc/my.cnf owner=mysql mode=0644″

四、Playbook 编排:让部署和配置真正可复用

Playbook 是 Ansible 的灵魂,用 YAML 描述“谁(hosts)、做什么(tasks)、怎么容错(handlers、when、failed_when)”。一个典型 Web 部署示例:

  • 开头定义目标主机组、变量(如 app_version: v2.3)、远程用户
  • tasks 中依次:安装 Nginx → 拷贝配置文件 → 启用并启动服务 → 验证端口是否监听
  • notify: restart nginx 触发 handlers,避免重复重启
  • 加上 tags: deploy,config,后续可只运行某部分:ansible-playbook site.yml –tags deploy

基本上就这些。不复杂但容易忽略的是:inventory 要定期同步、playbook 要 git 管理、敏感变量用 ansible-vault 加密。跑通一次,后续所有服务器交付、扩缩容、配置修复,都变成敲一行命令的事。

text=ZqhQzanResources