博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
001. Ansible简介
阅读量:5125 次
发布时间:2019-06-13

本文共 1309 字,大约阅读时间需要 4 分钟。

一 简介

Ansible是一款极其简单的自动化运维工具, 基于Python开发, 集合了众多运维工具(puppet, cfengine, chef, func, fabric)的优点。 实现了批量系统配置, 批量程序部署, 批量运行命令等功能。

Ansible是基于模块工作的, 本身没有批量部署的能力。真正具有批量部署的是ansible所运行的模块, Ansible只是提供一种框架。主要包括:

  1. Play books:任务剧本(任务集),编排定义Ansible任务集的配置文件,由Ansible依次执行多个任务,通常是JSON格式的YML文件;
  2. Host inventory: Ansible管理主机的清单,指定操作的主机, 是一个配置文件里面定义监控的主机;
  3. Modules:各种模块核心模块, command模块等,也包括自定义模块;
  4. Connection plugins: 负责和被监控端实现通信;
  5. Plugins:模块功能的补充,如连接类型插件、循环插件、变量插件等,可借助于插件完成更丰富的功能。

二 工作机制

  1. 用户使用Ansible或Playbook,在服务器中断输入Ansible的Ad-Hoc命令集或Playbook;
  2. Ansible遵循预先编排的规则将Playbooks逐条拆解为Play;
  3. Play组织成Ansible可识别的任务(Task);
  4. Task会调用任务所涉及的所有模块(Module)和插件(Plugin);
  5. 读取Inventroy中定义的主机列表;
  6. 通过SSH认证(默认)将任务集以临时文件或命令的形式传输到远程客户端执行并返回执行结果。

三 特性

  1. no agents: 不需要在被管控主机上安装任何客户端,只需SSH、Python即可,建议Python版本为2.6.6以上;
  2. no server: 无服务器端, 使用时直接运行命令即可;
  3. modules in any languages: 基于模块工作, 丰富的内置模块,可使用任意语言开发模块;
  4. yaml, not code: 使用yaml语言定制剧本playbook,易于管理,API简单明了;
  5. ssh by default: 基于SSH工作,整个过程简单、方便、安全,建议使用公钥方式认证;
  6. strong multi-tier solution: 可实现多级指挥。

四 优点

    (1).轻量级, 无需在客户端安装agent, 更新时只需在操作机上进行一次更新即可;

    (2).批量任务执行可以写成脚本, 而且不用分发到远程就可以执行;

    (3).使用python编写, 维护更简单, ruby语法过于复杂;

    (4).支持sudo。

五 应用场景

5.1 操作角度划分

  • 文件传输:文件的本地传输和异地传输,所有文件的空间形态、时间形态变化均构成文件传输类操作;
  • 命令执行:终端所有操作对系统来说都是指令的组成,对运维操作的用户行为来说,除文件传输以外的其他操作均可称为命令操作。

5.2 工作类型划分

  1. 应用部署
  2. 配置管理
  3. 任务流编排

 

转载于:https://www.cnblogs.com/itzgr/p/10297231.html

你可能感兴趣的文章
vue value key
查看>>
浅析STL allocator
查看>>
【原创】SqlServer 2005 BCP命令详解
查看>>
你让我怎么说
查看>>
implicit request ?
查看>>
POJ 1860 Currency Exchange (SPFA松弛)
查看>>
js fn无法访问,不报错
查看>>
Python网络编程(1)-socket
查看>>
计算机原理
查看>>
javascript 运算符优先级
查看>>
自学前端,你要的学习资料到了~~~~~~
查看>>
树的直径,树的最长路dp思想
查看>>
文件属性操作
查看>>
程序员的功法
查看>>
orcale 基本查询(1)
查看>>
HDU 1827 Summer Holiday
查看>>
mysql中char与varchar的区别分析
查看>>
第二次作业
查看>>
UVA-714 二分
查看>>
2019/2/12 Python今日收获
查看>>