今天遇到这样一个需求:在对A服务器执行一个操作任务的时候,同时也要把该操作任务在B服务器执行,如在A服务器添加一条hosts 记录: 1.1.1.1 abc.com 。这个必须是要在一个 playbook 完成,而且B服务器只需要执行这一个操作任务,其它操作任务不需要执行。也就是A服务器这一个操作任务与B服务器有依赖关系。

一开始这个需求可能通过ansible 是完成不了,但是在查阅了 ansible 文档后,发现ansible的任务委派(delegate_to)功能可以很好的完成这一要求。先看看ansible 官网文档对任务委派功能的描述:

Delegation

New in version 0.7.

This isn’t actually rolling update specific but comes up frequently in those cases.

If you want to perform a task on one host with reference to other hosts, use the ‘delegate_to’ keyword on a task. This is ideal for placing nodes in a load balanced pool, or removing them. It is also very useful for controlling outage windows. Using this with the ‘serial’ keyword to control the number of hosts executing at one time is also a good idea:

Ansible默认在配置的机器上执行任务,当你有一大票机器需要配置或则每个设备都可达的情况下很有用。但是,当你需要在另外一个Ansible控制机器上运行任务的时候,就需要用到任务委派了。

使用delegate_to关键字就可以委派任务到其他机器上运行,同时可用的fact也会使用委派机器上的值。下面的例子使用get_url到所有web服务器上下载配置:

---
- name: Fetch configuration from all webservers
hosts: webservers

tasks:
- name: Get config
get_url: dest=configs/` ansible_hostname ` force=yes url=http://` ansible_hostname `/diagnostic/config
delegate_to: localhost

当你委派给本机的时候,还可以使用更快捷的方法local_action,代码如下:

---
- name: Fetch configuration from all webservers
hosts: webservers

tasks:
- name: Get config
local_action: get_url dest=configs/` ansible_hostname`.cfg url=http://` ansible_hostname`/diagnostic/config
你可以委派任务给设备清单上的任意机器,下面是使用任务委派的一些场景:

  • 在部署之前将一个主机从一个负载均衡集群中删除

  • 当你要对一个主机做改变之前去掉相应dns的记录

  • 当在一个存储设备上创建iscsi卷的时候

  • 当使用外部的主机来检测网络出口是否正常的时候

下面描述下我的场景,如我要在192.168.1.1 服务器添加一个hosts 记录 "1.1.1.1 www.abc.com" ,同时也要把这个hosts 记录写到192.168.1.2

ansible hosts 192.168.1.1 文件内容

[all]

192.168.1.1

ansible task 文件内容(192.168.1.1.yml):

---

- name: add host record
shell: "echo "1.1.1.1 www.abc.com" >> /etc/hosts"

- name: add host record
shell: "echo "1.1.1.1 www.abc.com" >> /etc/hosts"
delegate_to: 192.168.1.2

# 添加上面这一行,就可以了

执行playbook

ansible-playbook -i 192.168.1.1.host 192.168.1.1.yml

转载于:https://blog.51cto.com/simpledevops/1653191

ansible 的任务委派功能(delegate_to)相关推荐

  1. ansible系列5-开启加速 Ansible 执行速度的功能

    SSH pipelining 是一个加速 Ansible 执行速度的简单方法.ssh pipelining 默认是关闭,之所以默认关闭是为了兼容不同的 sudo 配置,主要是 requiretty 选 ...

  2. ansible delegate_to 模块

    文章目录 1. 场景介绍 2. 委托(delegate) 3. 委托者的facts 4. run_once 1. 场景介绍 在对一组服务器 server_group1 执行操作过程中,需要在另外一台机 ...

  3. Ansible 教程

    1. Ansible 介绍 Ansible 是一个简单的自动化引擎,可以完成配置管理.应用部署.服务编排等需求.Ansible 是一款使用 Python 语言开发实现的开源软件,依赖 Jinja2.p ...

  4. Ansible中的playbook详解

    首先简单说明一下playbook,playbook是什么呢? 根本上说playbook和shell脚本没有任何的区别,playbook就像shell一样,也是把一堆的命令组合起来,然后加入对应条件判断 ...

  5. linux-运维自动化之ansible

    运维自动化之ANSIBLE 本章内容 运维自动化发展历程及技术应用 Ansible命令使用 Ansible常用模块详解 YAML语法简介 Ansible playbook基础 Playbook变量.t ...

  6. ansible自动化运维(一)——基本架构简介

    1.介绍 ansible是一种自动化运维工具,基于paramiko开发的,并且基于模块化工作,Ansible是一种集成IT系统的配置管理.应用部署.执行特定任务的开源平台. 它是基于python语言, ...

  7. Ansible 基础-介绍

    Ansible 工具集的组成,Ansible 共有6部分组成: 1,Ansible Playbook :任务剧本(任务集),编排定义Ansible 任务集的配置文件,由Ansible 顺序执行,通常是 ...

  8. 运维自动化------ansible搭建

    运维自动化发展历程及技术应用 IaaS基础设施即服务(相当于卖硬件) ,PaaS平台即服务(卖操作系统),SaaS软件即服务(卖软件) 企业实际应用场景分析 灰度环境(生产环境的一部分) 功能:在全量 ...

  9. Ansible基础入门

    1.1 Ansible是什么         随着移动互联.物联网.互联网+.大数据.云计算等大规模应用的催生推动,以及人们日常生活的互联网化,互联网的蓬勃发展不仅冲击影响着整个经济体,更对人们的生活 ...

最新文章

  1. 大数据笔记2019.5.6
  2. 皮一皮:成人世界的潜台词...
  3. PMCAFF | 十大最坑爹的产品设计缺陷你遇到过几个?
  4. mysql 自带 数据库_mysql自带的4个数据库介绍
  5. 【转】DB2学习路线
  6. 配置 --- vscode中react格式化解决方案
  7. django-orm操作流程
  8. [android]qq输入法手机版 v1.0 build0580,腾讯Android版手写输入法惊艳亮相 手写更畅快...
  9. cad自动标注界址点_CAD自带“块属性”即可实现自动标注坐标
  10. pythonffmpeg 推流_ffmpeg推流和播放命令
  11. Tomcat自动生成会话JSESSIONID
  12. 暗时间--平凡与优秀间的距离
  13. 51Nod - 1384 全排列
  14. c语言计算sum,C++ partial_sum(STL partial_sum)部分和计算方法详解
  15. Catch the moments of your life. Catch them while you're young and quick.
  16. Vue整合Markdown组件+SpringBoot文件上传+代码差异对比
  17. springcloud-alibaba-sentinel(1)sentinel流量卫兵介绍
  18. Qt QScopeGuard学习
  19. 【AAD Connect】01:AAD Connect把本地AD账户同步到Office365(AD域账户迁移)
  20. android应用开发完全

热门文章

  1. 解决Word 生成目录时前导符不一致的问题(即通常所谓的目录中省略号大小不一致)...
  2. PPT中嵌入视频详细解说
  3. 腾讯云直播的介绍以及如何设置直播?
  4. PLSQL从excel 导入数据
  5. Spring来一发 --- 目录
  6. 如何学习数据结构?(纯干货)
  7. 并网系统和离网光伏系统有什么不同?
  8. MySQL--增删改查基本操作
  9. 翼展科技研发实习生面试
  10. OpenStack之Glance