Ansible (软件)

✍ dations ◷ 2025-11-14 20:17:20 #Ansible (软件)

Ansible是一套软件工具,其可实现基础架构即程式码(英语:Infrastructure as code)。它是开源的,并且该套件包括软件供应、组态管理和应用程序部署等功能。

Ansible 最初由 Michael DeHaan 编写,并于 2015 年被Red Hat收购,其旨在自动化设定类 Unix系统和Microsoft Windows 的环境。Ansible 是无代理(英语:Software agent)的,借由透过SSH或允许PowerShell执行的Windows 远端管理机制来建立临时远端连线。 Ansible 的控制节点在大多数已安装Python的类 Unix 系统上执行,亦包含安装了WSL的 Windows系统。 系统组态(英语:System configuration)部分是透过使用它自己的宣告式语言来定义的。

"ansible"一词是由Ursula K. Le Guin在她 1966 年的小说中所创造的,指的是虚构的即时通讯系统。

Ansible 工具是由供应服务器应用程序Cobbler的作者与用于远端管理的Fedora 统一网络控制器(Func) 框架其合著者 Michael DeHaan 所开发。

Ansible, Inc. (原 AnsibleWorks, Inc.) 是由 Michael DeHaan、Timothy Gerla 和 Saïd Ziouani 于 2013 年所创立的公司,旨在为 Ansible 提供商业支持和赞助。 红帽公司 于2015 年 10 月收购了 Ansible。

Ansible 被包含在Red Hat所拥有的 Fedora Linux 发行版中,也可透过 Extra Packages for Enterprise (EPEL) 套件用于Red Hat Enterprise Linux、CentOS、openSUSE、SUSE Linux Enterprise、Debian、Ubuntu、Scientific Linux和Oracle Linux以及其他作业系统。

Ansible 借由选择以简单的 ASCII 文字档案来储存的部分 Ansible 存储库来帮助管理多台设备。存储库是可配置的,而目标机器的存储库可以动态取得,也可以从云端服务中不同档案格式 (YAML、INI)的来源中取得。

从 2014 年以来,敏感资料可以使用 Ansible Vault 储存在加密文件中。与其他流行的组态管理软件 (如Chef 、 Puppet 、 Salt和CFEngine) 相比,Ansible 使用,亦即 Ansible 软件无须在控制节点上正常运行,甚至无须安装在控制节点上。Ansible 借由透过 SSH 临时在节点上安装和执行模组来管理节点。在执行一个管理任务期间,执行模组的行程使用基于JSON的协定在其标准输出入界面来与被控制的机器沟通。当 Ansible 不管理节点时,因为没有执行任何后台程式或安装任何软件。 ,它不会消耗节点上的资源

Ansible 要求在所有被管理的机器上安装Python ,包含pip套件管理器、组态管理软件以及其相依套件。受控网络设备不需要额外的相依套件,并且是无代理状态的。

控制节点 (主控主机) 主要是在管理 (协调) 目标机器(称为 "存储库" 的节点,见下文)的运作。 控制节点仅适用于Linux等操作系统,不支援Windows操作系统。其允许多个控制节点。 Ansible 不需要单一控制机器来进行协调管理,其确保可用简单的方式来做灾难复原。节点是由控制节点透过SSH来管理。

Ansible 的设计目标包括:

模组大多是独立的,可以用标准脚本语言 (如 Python、Perl、Ruby、Bash 等) 来撰写。模组的指导目标之一是幂等性,这意味着即使多次重复操作 (例如从系统错误中复原时),它也会始终将系统置于相同的状态。

目标节点的位置是透过 (在 Linux 系统上) 位于 /etc/ansible/hosts 的清单配置列表 (INI或YAML格式) 来指定。 配置文件列出了 Ansible 可访问的每个节点的 IP 地址或主机名称。此外,可以用群组的方式来分配节点。

以下是一份范例清单 (INI 格式):

192.168.6.1foo.example.combar.example.com

此配置文件指定了三个节点:第一个节点由 IP 地址指定,后两个节点由主机名称来指定。此外,后两个节点被分配给 webservers 群组。

Ansible 还可以使用自定义的脚本,该脚本可以从不同的系统中动态取得资料,并支援以群组来分配群组。

Playbook 脚本是内含任务列表的YAML文件,其用于在受控节点上重复 执行。 每个 Playbook 都将一组主机映射 (关联) 到一组角色。每个角色都由对 Ansible 任务的呼叫来表示。

Ansible 自动化平台 (Ansible Automation Platform) 是一个REST API 、 Web 服务和基于 Web 的界面(应用程序),旨在使具有广泛 IT 技能的人更容易使用 Ansible。它是一个由多个组件组成的平台,包括开发人员工具、操作界面以及自动化网络,以实现跨数据中心的大规模自动化任务。 AAP 是 Red Hat, Inc. 支持的商业产品,但衍生了 17 个以上的上游开源项目,包括 AWX 上游项目 (Ansible Tower 衍生自该项目的前身),该项目自 2017 年 9 月开始开源。

还有另一个 Tower 的开源替代品 ,它是用Go编写的。

控制机器必须是 Linux/Unix 主机(例如BSD 、 CentOS 、 Debian 、 macOS 、 Red Hat Enterprise Linux 、 SUSE Linux Enterprise 、 Ubuntu ,并且需要 Python 2.7 或 3.5。

托管节点(如果它们是类 Unix)必须具有 Python 2.4 或更高版本。对于使用 Python 2.5 或更早版本的托管节点,还需要python-simplejson套件包。 从 1.7 版本开始,Ansible 还可以管理Windows 节点。 在这种情况下,将使用 WS-Management 协议支持的本机 PowerShell 远程处理,而不是 SSH。

Ansible 可以部署到裸机主机、虚拟机和云环境。

AnsibleFest 是让 Ansible 社群用户、贡献者等人参加的年度研讨会。

相关

  • 有袋类有袋上目(学名:Marsupialia)动物是雌性个体的腹部下长有育幼袋的哺乳类动物,如袋鼠、袋狼、树袋熊、负鼠、袋貂、袋狸等。现存物种如袋鼠、树袋熊主要分布于澳洲及附近岛屿,负鼠
  • 院长中华民国立法院院长是中华民国立法院之首长,相当于国会议长,由中华民国立法委员相互提名投票选举后产生,依法督导监管立法院委员会,组织中华民国立法院决策程序与行政议事,并负责
  • GeV电子伏特(英语:electron volt),简称电子伏,符号为eV,为能量单位。代表一带电量为1.602 176 634 x 10−19库仑的电子 在真空中通过 1 伏特电位差所产生的动能。电子伏与SI制的能量
  • 2010年美国羽毛球黄金大奖赛2010年美国羽毛球黄金大奖赛为第2010年度的美国羽毛球公开赛,是2010年世界羽联大奖赛的其中一站。本届赛事于2010年7月19日至7月24日在美国加利福尼亚州的橙县举行,并获得YONE
  • PythonPython(英国发音:/ˈpaɪθən/ 美国发音:/ˈpaɪθɑːn/)是一种广泛使用的解释型、高级编程、通用型编程语言,由吉多·范罗苏姆创造,第一版发布于1991年。Python是ABC语言的后继
  • .mk.mk为北马其顿国家及地区顶级域(ccTLD)的域名。A .ac .ad .ae .af .ag .ai .al .am .ao .aq .ar .as .at .au .aw .ax .az  B .ba .bb .bd .be .bf .bg .bh .bi .bj .bm .
  • 不要不急线不要不急线(日语:不要不急線/ふようふきゅうせん  */?)是日本的专有铁路名称,所指的是于第二次世界大战中期至后期,日军为确保有足够的金属原料去制造武器,于是下令要求将部分铁
  • 死谷国家公园死谷国家公园(Death Valley National Park)是美国国家公园,位于美国干旱的大盆地里内华达山脉东部的加州和内华达州。该公园包围着莫哈韦沙漠(Mojave De
  • 罗兰·布吕克纳罗兰·布吕克纳(德语:Roland Brückner,1955年12月14日-),德国前男子竞技体操运动员。他曾参加1976年和1980年两届夏季奥运会,共收获一枚金牌、一枚银牌和三枚铜牌。
  • M4M4可以指: