Ansible(From Wikipedia)

       Ansible 是一个免费的用于配置和管理计算机的的软件平台。它集成了软件部署,ad hoc任务执行,和管理配置的功能。它依赖Python2.4之后的版本和通过SSH或者PowerShell管理节点。模块工作在JSON格式,输出信息可以被任何编程语言再次编写。系统管理员可以使用YAML来描述系统的可用状态 ( The system uses YAML to express reusable descriptions of systems.)

       这个平台由Michael DeHaan所创建。Micahael DeHaan是系统提供工具 Cobbler的作者和提供远程管工具理Func框架的合著者。它被包含在Fedora发行版里面,同时也可以被RHELCentOSScientific Linux和其它操作系统使用。2015年,10-16Red hat宣布它已经取得了ansible的所有权。

为什么被称作Ansible

It was named "Ansible" after the fictional instantaneous hyperspace communication system featured in Orson Scott Card'sEnder's Game,[9] and originally invented by Ursula K. Le Guin for her 1966 novel Rocannon's World.

 

1、架构(Architecture)

       就像许多配置管理软件一样,Ansible区分两种不同类型的服务器:控制器节点。首先,一个控制器作为编排(orchestration)开始的地方,然后节点由控制器通过SSH管理。控制器通过它的清单文件(inventory)描述节点的位置。

       为了编排节点,Ansible通过SSH在节点上部署模块(Ansible deploys modules to nodes over SSH)。模块暂时存储在节点然后和通过JSON协议产生标准输出和控制节点通信。当Ansible没有管理节点的时候,它也不会消耗任何资源,因为后台没有Ansible daemon或程序在执行。

       对比其它流行的配置管理软件,例如ChefPuppet,和CFEnineAnsible使用无状态的架构。基于Agent的架构,节点必须在本地安装一个daemon来和控制器通信。而无Agent的架构,节点不需要安装和运行任何后台daemons来连接控制节点。而无Agent的架构减少了节点不断polling控制器时候的网络负载。

 

1.1设计目标:

Ansible的设计目标包括:

最小化原则(Minimal in nature.)管理系统应尽量减少额外的依赖关系。

一致性(声明需要)

安全. Ansible不部署不安全的Agent。只需要OpenSSH即可,而OpenSSH是被测试过的。

高可靠性 幂等性模型防止重新执行脚本的副作用。

低学习门槛。Playbook使用一个容易的和容易描述的基于YMAL的语言。

1.2模块:

模块被看做Ansible的基本工作单元。每个模块都是独立的,同时可以被任何脚本语言编写,例如Python,Perl,Ruby,bash等等。模块的属性之一是幂等性,这意味着尽管某一操作执行了无数次,但是系统还是停留在相同的状态。

1.3清单配置(Inventory Configurations)

       清单用于描述可以被Ansible访问的节点。这个清单默认被一个配置文件描述,位于/etc/ansible/hosts。这个配置文件列出可以被Ansible访问的IP地址或者每个主机的主机名。另外,节点也可以被分配到一个组里面。

下面看一个例子:

192.168.6.1
 
[webservers]
foo.example.com
bar.example.com

这个配置文件指定了三个节点。第一个通过IP地址指定,后面两个通过主机名指定。另外后面两个节点被划分到webserver组里面了。

Ansible也可以执行自定义的动态清单(Dynamic Inventory)脚本,可以从任何软件系统拉取数据让自己使用。

1.4剧本(Playbook)

PlaybookAnsible中表述配置,部署,和编排。Playbook使用YMAL语法,每个playbook映射一组主机到一些角色上。每个角色都是由Ansible任务调用。

 

2、平台支持:

    控制节点必须有Python2.6. 支持的操作系统包括大部分LinuxUnix发行版,例如Red HatDebianCentOSOS XBSD等等。

    管理节点必须有Python2.4或后面的版本。被管理的节点使用Python2.5或更早的包,python-simplejson包需要被安装。在Ansible 1.7版本之后,Ansible也可以管理Windows节点了。

2.1云集成环境

Ansible可以部署虚拟化环境和公共和私有云环境,.包括VMvareOpenStackAWSRackspace Cloud ServersDigitalOcean Droplets, Eucalyptus CloudKVMXenServerSoftLayerMicrosoft Azure  CloudStack

2.2大数据集成

Ansible可以部署大数据,存储和处理分享环境,包括HadoopRiak, and AerospikeAnsible处理的问题包括管理每个节点的资源消耗。由其是大数据,存储和分析环境需要很高的执行效率和尽可能的消耗少量的CPU时间和内存。更深入的说,Ansible还提供监控功能,测量物理量如CPU资源可以帮助管理这些节点

 

3、用户:

很多公司都在使用。

原创文章,作者:艾贺,如若转载,请注明出处:http://www.178linux.com/9284

(0)
艾贺艾贺
上一篇 2015-11-18
下一篇 2015-11-18

相关推荐

  • CentOS6 网络管理之网卡配置及简单路由设置

    CentOS6中关于网络配置的命令有很多,本文将介绍几个平时最长用的几个命令,以及网卡IP地址的配置和简单路由配置。 1、经常使用的查看IP地址命令为 ifconfig,不跟参数的情况下默认查看所有已启用的网卡信息,如下图所示: 如果想查看具体某块网卡信息,则可以在ifconfig后面跟上网卡设备,如只查看eth0的信息则执行:ifconfig eht0 即…

    Linux干货 2016-09-05
  • 用户和组的四大配置文件简介

    一. 用户的由来 linux系统拥有的就是资源,最重要的事就是对资源的分配,资源分给谁?在linux上资源的访问是对用户赋予不同的权限实现,也就是说能访问资源的单位是用户。那用户在获取资源之前要实现证明自己是本用户,这个过程称为认证,他通过密码和用户名实现。在用户登录时会将用户输入的用户名和密码进行校验,校验过程就是将输入的用户名和密码与linux系统上记录…

    Linux干货 2016-10-24
  • 正则表达式字符集

    POSIX Description ASCII Unicode Shorthand Java [:alnum:] Alphanumeric characters [a–zA–Z0–9] [\p{L}\p{Nl}  \p{Nd}] \p{Alnum} [:alpha:] Alphabetic characters …

    Linux干货 2017-07-07
  • iptables/netfilter入门到进阶

    防火墙的概念 Firewall:工作于主机或网络边缘,对于进出本主机或网络的报文根据事先定义的规则作匹配检测,对于更改被规则匹配到的报文做出相应处理的组件 网络层防火墙(包过滤防火墙): 优点:对用户来说透明,处理速度快且易于防护 缺点:一旦黑客突破防火墙,就可以请以伪造数据包源地址、目的地址和IP端口号 代理服务型防火墙(Proxy Service) 优点…

    2017-06-17
  • 1019作业

    1019作业 柴震 软连接 硬连接 软连接和硬链接的区别 属性与定义: 硬链接:新建的文件是已经存在的文件的一个别名,所以创建时链接数递增;而且当原文件删除时,新建的链接文件仍然可以使用,因其直接对应于数据块。 软链接:也称为符号链接。新建的链接文件以“路径”的形式来表示另一个文件,其大小为指向的路径字符串的长度,不增加或减少目标文件in…

    Linux干货 2016-10-19
  • Centos6.5上搭建openvpn

    前言     为了方便远程办公时访问公司的内部系统,如:svn、OA、wiki、禅道等等;通通在防火墙上做了端口映射。发现有时也不好用,所有开始弄OPENVPN。 openvpn简介     官方网站:https://openvpn.net 打不开请爬墙   &nbsp…

    Linux干货 2016-02-14