当前位置: 首页 > news >正文

Ansible 配置Playbook文件格式、关键字和语法详解

Ansible Playbook 使用 YAML 格式编写,通过定义任务流程实现自动化。以下是 Playbook 的核心结构、关键字和语法详解:


一、Playbook 基础结构

1. 基本框架
---
- name: Play 1 Description  # Play 的名称hosts: target_host_group  # 目标主机组(来自 Inventory)become: yes               # 是否提权(sudo)vars:                     # 定义变量http_port: 80tasks:                    # 任务列表- name: Task 1          # 任务名称module_name:          # 模块名称(如 apt, copy)module_parameter: value- name: Play 2 Description  # 另一个 Play(按顺序执行)hosts: another_grouptasks: [...]

二、核心关键字详解

1. Play 级别关键字
关键字说明
namePlay 的描述性名称(可选,但推荐使用)
hosts目标主机组或主机模式(如 web_servers 或 192.168.1.*
become是否提权(默认 no),等同于 sudo
vars定义 Play 级变量
vars_files引入外部变量文件(如 vars/main.yml
tasks定义任务列表
handlers定义处理器(由任务触发,如重启服务)
roles引入角色(模块化复用代码)
pre_tasks在 tasks 前执行的任务列表
post_tasks在 tasks 后执行的任务列表
environment设置环境变量
any_errors_fatal任一任务失败时终止整个 Play(默认 no

2. Task 级别关键字
关键字说明
name任务的描述(必填,清晰描述任务作用)
module调用的 Ansible 模块(如 aptcopy
args模块参数(替代行内参数写法,适用于复杂场景)
when条件判断(仅在条件满足时执行任务)
loop循环执行任务(替代旧版 with_items
register将任务结果保存到变量
ignore_errors忽略任务失败(默认 no
changed_when定义任务何时标记为 "changed" 状态
failed_when定义任务何时标记为 "failed" 状态
tags为任务打标签,方便选择性执行
retries任务失败重试次数(常与 until 结合)
delay重试间隔时间(秒)
until重试直到条件满足

3. Handler 关键字
handlers:- name: restart_nginxservice:name: nginxstate: restarted
  • 由任务中的 notify 触发,按定义顺序执行。

  • 仅在所有任务执行完毕后触发一次(即使被多次通知)。


三、语法细节与示例

1. YAML 格式要求
  • 缩进:使用 2 个空格(非 Tab)。

  • 列表:以 - 开头。

  • 字符串:可省略引号,但包含特殊字符时需用 " 或 ' 包裹。

2. 变量定义与引用
vars:package_name: nginxconfig_path: "/etc/{{ package_name }}/nginx.conf"tasks:- name: Install Packageapt:name: "{{ package_name }}"
3. 条件判断 (when)
- name: Install EPEL on CentOSyum:name: epel-releasestate: presentwhen: ansible_os_family == 'RedHat'
4. 循环 (loop)
- name: Add Usersuser:name: "{{ item }}"state: presentloop:- user1- user2
5. 错误处理
- name: Ignore Failed Taskcommand: /bin/falseignore_errors: yes- name: Retry Taskshell: /opt/start_service.shretries: 3delay: 10
6. 注册变量 (register)
- name: Check Service Statuscommand: systemctl is-active nginxregister: service_status- name: Debug Statusdebug:var: service_status.stdout

四、模块化与复用

1. Include 与 Import
方法说明
import_playbook导入另一个 Playbook(静态,预处理阶段解析)
import_tasks导入任务文件(静态)
include_tasks动态包含任务文件(根据条件或循环动态加载)

示例:

- name: Include Common Tasksimport_tasks: common_tasks.yml
2. Roles 结构
roles/webserver/tasks/         # 主任务文件main.ymlhandlers/     # 处理器main.ymltemplates/    # Jinja2 模板nginx.conf.j2files/        # 静态文件index.htmlvars/         # 角色变量main.ymldefaults/    # 默认变量(优先级最低)main.ymlmeta/        # 依赖声明main.yml

使用角色:

- name: Apply Web Server Rolehosts: web_serversroles:- webserver

五、高级功能

1. 加密敏感数据 (Vault)
# 加密文件
ansible-vault encrypt vars/secrets.yml# 运行 Playbook 时解密
ansible-playbook site.yml --ask-vault-pass
2. 动态 Inventory
# inventory.ini
[web_servers]
localhost ansible_connection=local[all:vars]
ansible_python_interpreter=/usr/bin/python3
3. 异步任务
- name: Long Running Taskcommand: /path/to/long_script.shasync: 3600    # 最大运行时间(秒)poll: 0        # 不等待结果register: async_result- name: Check Async Taskasync_status:jid: "{{ async_result.ansible_job_id }}"register: job_resultuntil: job_result.finishedretries: 30

六、调试与验证

1. 语法检查
ansible-playbook playbook.yml --syntax-check
2. 空运行 (Dry Run)
ansible-playbook playbook.yml --check
3. 详细日志
ansible-playbook playbook.yml -v       # -v 到 -vvvv(详细程度递增)
4. 标签执行
tasks:- name: Install Packagesapt: name=nginxtags: install- name: Copy Configcopy: src=nginx.conf dest=/etc/nginx/tags: config
ansible-playbook playbook.yml --tags "install,config"

七、最佳实践

  1. 命名清晰:为 Play 和 Task 使用有意义的名称。

  2. 模块优先:尽量使用 Ansible 内置模块而非原始 Shell 命令。

  3. 变量分离:敏感数据通过 Vault 加密,通用变量放在 group_vars/ 或 host_vars/

  4. 幂等性:确保任务可重复执行且结果一致(如使用 state: present 而非 latest)。

  5. 版本控制:将 Playbook 和 Roles 纳入 Git 管理。


八、完整 Playbook 示例

---
- name: Configure Web Serverhosts: web_serversbecome: yesvars:http_port: 8080max_clients: 200vars_files:- vars/secrets.ymltasks:- name: Install Nginxapt:name: nginxstate: presenttags: install- name: Copy Nginx Configtemplate:src: templates/nginx.conf.j2dest: /etc/nginx/nginx.confnotify: Restart Nginxtags: config- name: Ensure Nginx Runningservice:name: nginxstate: startedenabled: yestags: servicehandlers:- name: Restart Nginxservice:name: nginxstate: restarted

http://www.xdnf.cn/news/667747.html

相关文章:

  • 每日Prompt:古花卷
  • 探究Azure devops 流水线缓存
  • 详解MYSQL索引失效问题排查
  • 关于 Web 安全:6. 常见 CMS 开源系统风险点
  • 利用 `ngx_http_xslt_module` 实现 NGINX 的 XML → HTML 转换
  • 深度学习常用概念详解:从生活理解到技术原理
  • 新电脑配置五 jdk8,maven,idea,vscode
  • 单片机(MCU)的 IO 口静电、浪涌、电压异常等保护
  • OpenEuler-DNS多域服务器搭建
  • 基于 Node.js 的 Express 服务是什么?
  • div或button一些好看实用的 CSS 样式示例
  • Linux 下 C 语言实现工厂模式
  • 卓力达蚀刻工艺:精密制造的跨行业赋能者
  • day 33 python打卡
  • 【LeetCode 热题 100】打家劫舍 / 零钱兑换 / 单词拆分 / 乘积最大子数组 / 最长有效括号
  • DAY38打卡
  • Python打卡第38天
  • 零基础远程连接课题组Linux服务器,安装anaconda,配置python环境(换源),在服务器上运行python代码【2/3 适合小白,步骤详细!!!】
  • K8S Pod调度方法实例
  • 详解K8s API Server 如何处理请求的?
  • MySQL connection close 后, mysql server上的行为是什么
  • 【Elasticsearch】调用_flush api会调用_refresh 吗?
  • 火山引擎声音复刻
  • 安全生产例题
  • 知识图谱:AI时代语义认知的底层重构逻辑
  • 游戏引擎学习第314天:将精灵拆分成多个层
  • U 盘数据恢复全攻略
  • 说说 Kotlin 中的 Any 与 Java 中的 Object 有何异同?
  • Go 应用中的 Redis 连接与操作
  • NLua性能对比:C#注册函数 vs 纯Lua实现