常用的自动化管理软件及Ansible安装

文章目录

  • 常用的自动化管理软件及Ansible安装
    • 1. Puppet
    • 2. CHEF
    • 3. CFEngine
    • 4. Foreman
    • 5. Katello
    • 6. Nagios
    • 7. Ansible
      • 什么是 Ansible?
      • Ansible 无需代理
      • Ansible 方式
      • 控制节点
      • 受管主机
      • 基于Windows的受管主机
      • 受管网络设备
      • 安装Ansible

1. Puppet

Puppet是一款开源工具,旨在为系统管理员大大简化自动化和报告工作。它基本上是款配置管理软件,有助于配置和维护企业网络中的服务器及其他系统。系统管理员通常每天要花大量时间重复做同样的任务。他们总是想要使这些任务实现自动化,以便有更多的时间来处理其他项目或学习新的概念和脚本语言。管理员可以通过编写脚本使任务实现自动化,但是在拥有大型网络的公司,脚本不是很方便。这时候,Puppet就大有用场,因为借助Puppet,你可以:

  1. 为网络上的每个主机定义独特的配置设置;
  2. 不断监测网络,查找任何变动;
  3. 帮助高效地创建和管理用户;
  4. 帮助管理每个开源工具的配置设置。

2. CHEF

Chef是另一款可供Linux系统管理员使用的流行的自动化工具。它用Ruby和Erlang编写,对于配置和维护公司的服务器大有帮助,无论贵公司拥有十台服务器还是上百台。它还可以帮助你将云端服务器与亚马逊EC2、OpenStack、RackSpace或谷歌云整合起来。Chef可以将你的基础设施转变成代码,那样借助代码,你只要更改几行代码,就能轻松撤下一台服务器,从而让你轻松管理服务器。物理节点还意味着:将变更内容部署到生产环境之前,可以对它轻松进行测试,你还可以轻松控制针对代码的每次更新的版本。Chef DK为你提供了测试和管理配置的所有工具,Chef Server充当你所有“菜谱”(recipe)的存储库,可以管理与服务器连接的每个节点。Chef客户软件在每个客户端上运行,时不时收到服务器方面的信息,从而更新其配置设置。

3. CFEngine

面向Linux系统管理员的下一款自动化工具是CFEngine,这是另一个领先的自动化系统,可帮助你轻松管理整套基础设施,并使之实现自动化。一旦你使用CFEngine为网络中的系统定义了配置,那么CF Engine就会自动确保配置符合规范。不用说,如果你的网络中有10个或100个节点,可以在短短几秒内更新或改动任何一个节点或所有节点。CFEngine之所以受到许多Linux系统管理员的青睐,是由于它运行成本低、响应速度快、具有自愈合功能。

4. Foreman

Foreman是另一种用于取证分析的开源配置管理工具。Foreman提供了仪表板,我们可以通过仪表板来配置裸机服务器和虚拟机。默认情况下,无论我们何时安装Foreman,它都使用Puppet作为配置工具。不过借助插件,Foreman还支持与其他配置管理工具整合起来,比如Chef、Puppet、Ansible、Salt及其他众多工具。Foreman自动化工具还随带各种各样的接口,包括命令行接口、Web前端以及REST API。Foreman的其他一些显著功能包括如下:

  1. 通过仪表板,管理Puppet模块和puppet类方面的改动;
  2. 很容易从Foreman仪表板来管理Puppet环境;
  3. 由于仪表板,创建主机群(Hosts Group)以及为主机群添加puppet模块变得很轻松;
  4. 可以从Foreman仪表板,轻松添加Puppet模块或推送到节点。

5. Katello

Katello是另一种开源自动化工具。换而言之,我们可以说Katello是一种开源版的Red Hat satellite Server;如果我们不想花钱在企业产品及其支持上,就可以用它来代替Red Hat satellite Server。Katello已被Foreman收购,Foreman中的大部分功能在Katello中也得到了支持。Katello Server的主要功能如下:

  1. 给基于Linux的服务器(RHEL和CentOS )打补丁;
  2. 使用Pulp Service来同步代码库;
  3. 使用Foreman进行各种配置;
  4. 它还可以处理订阅内容管理,并审计所有已部署的软件包;
  5. 借助Katello,你可以为所有主机创建主机群,另外还可以在单一主机或一群主机上批量执行操作。

6. Nagios

Nagios现在名为Nagios Core,它是一种开源自动化和监控工具,可以管理基础设施中的所有系统。它还提供警报服务,一旦察觉到你的网络中哪里有问题,就会提醒系统管理员。借助SNMP以及Nagios,系统管理员还可以控制并管理打印机、路由器和交换机。Nagios让我们得以创建事件处理工具,一旦某个应用程序及其服务停运,就可以自动重启出现故障的那个应用程序及其服务。

7. Ansible

什么是 Ansible?

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

Ansible是基于模块工作的,本身没有批量部署的能力。真正具有批量部署的是Ansible所运行的模块,Ansible只是提供一种框架。主要包括:
(1) 连接插件connection plugins:负责和被监控端实现通信;
(2) host inventory:指定操作的主机,是一个配置文件里面定义监控的主机;
(3) 各种模块核心模块、command模块、自定义模块;
(4) 借助于插件完成记录日志邮件等功能;
(5) playbook:剧本执行多个任务时,非必需可以让节点一次性运行多个任务。

Ansible架构图:

Ansible 无需代理

Ansible 围绕无代理架构构建。通常而言,Ansible 通过 OpenSSH 或 WinRM 连接它所管理的主机并且运行任务,方法通常是将称为 Ansible 模块的小程序推送至这些主机。这些程序用于将系统置于需要的特定状态。在 Ansible 运行完其任务后,推送的所有模块都会被删除。

Ansible 不需要批准使用任何特殊代理,然后再部署到受管主机上。由于没有代理,也不需要额外的自定义安全基础架构,

Ansible 具有多个重要的优点:

  • 跨平台支持:Ansible 提供Linux、Windows、UNIX和网络设备的无代理支持,适用于物理、虚拟、云和容器环境。
  • 人类可读的自动化:Ansible Playbook采用YAML文本文件编写,易于阅读,有助于确保所有人都能理解它们的用途。
  • 完美描述应用:可以通过 Ansible Playbook进行每种更改,并描述和记录应用环境的每一个方面。
  • 轻松管理版本控制:Ansible Playbook和项目是纯文本。它们可以视作源代码,放在现有版本控制系统中。
  • 支持动态清单:可以从外部来源动态更新 Ansible 管理的计算机列表,随时获取所有受管服务器的当前正确列表,不受基础架构或位置的影响。
  • 编排可与其他系统轻松集成:能够利用环境中现有的 HP SA、Puppet、Jenkins、红帽卫星和其他系统,并且集成到 Ansible 工作流中。

Ansible 方式

Ansible 的设计宗旨是工具易用,自动化易写易读。所以在创建自动化时我们应追求简单化。

Ansible 自动化语言围绕简单易读的声明性文本文件来构建。正确编写的 Ansible Playbook可以清楚地记录你的工作自动化。

Ansible 是一种要求状态引擎。它通过表达你所希望系统处于何种状态来解决如何自动化IT部署的问题。Ansible 的目标是通过仅执行必要的更改,使系统处于所需的状态。试图将 Ansible 视为脚本语言并非正确的做法。

控制节点

Ansible 易于安装。 Ansible 软件只需要安装到要运行它的一个(或多个)控制节点上。由 Ansible管理的主机不需要安装 Ansible。

对控制节点的要求:

  • 控制节点应是Linux或UNIX系统。不支持将Windows用作控制节点,但Windows系统可以是受管主机。
  • 控制节点需要安装Python3(版本3.5或以上)或Python2(版本2.7或以上)。

如果操作系统是红帽8.0,Ansible 2.9可以自动使用 platform-python 软件包,该软件包支持使用Python的系统实用程序。你不需要从 AppStream安装python37或python27软件包。

[root@localhost ~]# yum list installed platform-python
Updating Subscription Management repositories.
Unable to read consumer identity
This system is not registered to Red Hat Subscription Management. You can use subscription-manager to register.
Installed Packages
platform-python.x86_64                   3.6.8-1.el8.0.1                    @anaconda

受管主机

Ansible的一大优点是受管主机不需要安装特殊代理。Ansible控制节点使用标准的网络协议连接受管主机,从而确保系统处于指定的状态。

受管主机可能要满足一些要求,具体取决于控制节点连接它们的方式以及它们要运行的模块。

Linux和UNIX受管主机需要安装有Python2(版本2.6或以上)或Python3(版本3.5或以上),这样才能运行大部分的模块。

对于红帽8,可以启用并安装python36应用流(或python27应用流)

yum module install python36

如果受管主机上启用了SELinux,还需要确保安装python3-libselinux软件包,然后才能使用与任何复制、文件或模板功能相关的模块。所以在工作的时候,应当把SELinux功能关闭。

基于Windows的受管主机

Ansible有许多专门为Windows系统设计的模块。这些模块列在https://docs.ansible.com/ansible/latest/modules/list_of_windows_modules.html部分中。

大部分专门为Windows受管主机设计的模块需要在受管主机上安装PowerShell 3.0或更高版本,而不是安装Python。此外,受管主机也需要配置PowerShell远程连接。Ansible还要求至少将.NET Framework 4.0或更高版本安装在Windows受管主机上。

受管网络设备

Ansible还可以配置受管网络设备,例如路由器和交换机。Ansible包含大量专门为此目的而设计的模块。其中包括对Cisco IOS、IOS XR和NX-OS的支持;Juniper Junos;Arsta EOS;以及基于VyOS的网络设备等。

我们可以使用为服务器编写playbook时使用的相同基本技术为网络设备编写Ansible Playbook。由于大多数网络设备无法运行Python,因此Ansible在控制节点上运行网络模块,而不是在受管主机上运行。特殊连接方法也用于与网络设备通信,通常使用SSH上的CLI、SSH上的XML或HTTP(S)上的API。

安装Ansible

主机名 ip 系统
ansible 192.168.159.167 centos8
//关闭防火墙
[root@ansible ~]# setenforce 0
[root@ansible ~]# sed -ri 's/^(SELINUX=).*/\1disabled/g' /etc/selinux/config
[root@ansible ~]# systemctl disable --now firewalld.service
Removed /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
//提供YUM源
[root@ansible yum.repos.d]# curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-vault-8.5.2111.repo% Total    % Received % Xferd  Average Speed   Time    Time     Time  CurrentDload  Upload   Total   Spent    Left  Speed
100  2495  100  2495    0     0  13861      0 --:--:-- --:--:-- --:--:-- 13861
[root@ansible yum.repos.d]# sed -i -e '/mirrors.cloud.aliyuncs.com/d' -e '/mirrors.aliyuncs.com/d' /etc/yum.repos.d/CentOS-Base.repo
//安装相关软件
[root@ansible ~]# dnf list all|grep ansible
ansible-collection-microsoft-sql.noarch                1.1.0-1.el8                                            AppStream
ansible-collection-redhat-rhel_mgmt.noarch             1.0.0-2.el8                                            AppStream
ansible-freeipa.noarch                                 0.3.8-1.el8                                            AppStream
ansible-freeipa-tests.noarch                           0.3.8-1.el8                                            AppStream
ansible-pcp.noarch                                     2.2.1-1.el8                                            AppStream
centos-release-ansible-29.noarch                       1-2.el8                                                extras
[root@ansible ~]# dnf -y install centos-release-ansible-29-1-2.el8.noarch
[root@ansible ~]# dnf -y install ansible
//查看ansible版本
[root@ansible ~]# ansible --version
ansible 2.9.27config file = /etc/ansible/ansible.cfgconfigured module search path = ['/root/.ansible/plugins/modules', '/usr/share/ansible/plugins/modules']ansible python module location = /usr/lib/python3.6/site-packages/ansibleexecutable location = /usr/bin/ansiblepython version = 3.6.8 (default, Jan 19 2022, 23:28:49) [GCC 8.5.0 20210514 (Red Hat 8.5.0-7)]
[root@ansible ~]#
//通过使用setup模块验证localhost上的ansible_python_version
[root@ansible ~]# ansible -m setup localhost | grep ansible_python_version"ansible_python_version": "3.6.8",
[root@ansible ~]#

常用的自动化管理软件及Ansible安装相关推荐

  1. 常用个人密码管理软件 .

    互联网现在已经完全融入到了我们的日常生活中了,一个普通人每天都会接触到互联网,各个网络服务和软件的登陆密码对我们每个人来说都是非常重要的,如果密码被盗其后果可想而知,月光博客在< 个人密码安全策 ...

  2. 文献管理软件 linux,5款常用的文献管理软件

    来源:木耶百新 编辑:小文 文献管理软件的便利之处在于: 可以直接联网到不同的数据库进行检索,免去登录不同数据库的劳累之苦,提高效率: 可以非常方便地管理文献信息,包括文摘.全文.笔记.以及其它的附件 ...

  3. ipad文献管理软件_Mac上四款常用的文献管理软件,哪款适合你?

    文献管理软件的作用主要是使我们可以很方便地管理和利用文献自己检索到的有用资料. 核心用途:写论文时的引文管理,这些是任何文献管理软件必备的核心功能 重要功能:管理题录使得可以快速高效地搜索到自己已经看 ...

  4. Redis 常用可视化客户端管理软件

    一.引言 现在开发过程中使用Redis的地方越来越多了,而且使用过程中,我们需要可能需要查看下Redis数据,但是命令行使用起来比较麻烦而且看起来不直观,当数据量比较多就比较麻烦,没可视化客户端看起来 ...

  5. Mac参考文献管理软件EndNote X8 安装教程

    EndNote X8 for Mac使用灵活的搜索,组织,共享研究和创建参考书目的工具,扩展了用户研究上的能力,并随时随地与EndNote库连接.今天要给大家分享的是Mac参考文献管理软件EndNot ...

  6. 自动化运维工具——ansible安装及模块介绍

    ansbile 前言 一.主流自动化运维工具简介 1.1 Puppet 1.2 Saltstack 1.3 Ansible 二.Ansible 运维工具原理 三.Ansible安装 3.1 下载软件包 ...

  7. 常用的自动化管理工具

    puppet 特点: puppet与其他手工操作工具有一个最大的区别是 puppet的配置具有稳定性,因此你可以多次执行puppet,一旦你更新了你的配置文件,puppet就会根据配置文件来更改你的机 ...

  8. 文献管理软件Zotero的安装和使用

    文章目录 前言 一.Zotero简介 二.安装与使用 1.账号注册 2.软件安装 3.插件安装 4.关联账户设置 5.坚果云扩充(WebDAV) 6.保存路径设置 7.与Connected Paper ...

  9. 附加驱动管理软件 ubuntu_linux下安装realtek8812au/8811au驱动

    一.正常简单的安装方法 对于kali系统安装非常方便: 1.确认系统已经联网.(ping baidu.com能通即可) 2.确认/etc/apt/sources.list文件中有可用的源(cat /e ...

最新文章

  1. A problem occurred evaluating project ':'. ASCII
  2. Angular2 组件通信
  3. Android Touch事件传递机制 二:单纯的(伪生命周期)
  4. Server.MapPath(path)的使用
  5. BiGAN-QP:简单清晰的编码 生成模型
  6. 使用wcstok_s函数分割路径, 创建多级目录
  7. POJ 3468 A Simple Problem with Integers(线段树区间更新)
  8. mysql sql执行慢_Mysql执行查询语句慢的解决方式
  9. java如何代码生成矩形_Java中能不能创建不是矩形的窗口。
  10. HTML5 音频 / 视频 DOM 操作
  11. 黑马程序员传智播客 python 迭代器学习笔记
  12. Matlab/Python两方,三方甚至四方演化博弈仿真图及 代码 演化博弈敏感性分析仿真图及相轨迹图/相位图及代码
  13. ZoomIt下载,ZoomIt下载地址分享
  14. 三维扫描仪[11]——总结并展望基于Kinect的三维扫描仪
  15. ps如何把自己的图与样机结合_如何用PS制作样机,并且看起来毫无痕迹
  16. 中台战略-建中台与拆中台
  17. 中国红木家具行业规模及投资风险评估报告2022-2028年
  18. 激活函数(sigmoid、tanh、ReLU、leaky ReLU)
  19. 【python简易小程序设计】设计一个 python程序,模拟投掷100次色子。若总点数大于300点时,则提前结束 统计最后投掷出的各点数数量(要求使用列表)并输出
  20. 2020:VL-BERT: Pre-training of generic visual-linguistic representation

热门文章

  1. 推荐几个免费的国外图像库,数字图像处理必备
  2. 什么是朋友圈广告,朋友圈广告优势,如何投放朋友圈广告?
  3. php 文字水印换行,php实现文字换行以及thinphp5.1水印自定义位置
  4. 抖音评论如何放置连接_给你一篇攻略,教你如何玩转抖音!
  5. 戴尔更新基于英特尔第四代处理器的PowerEdge服务器全系列型号:R660,R760,R760xd2,R760xs,R660xs,R760xa,R860,R960
  6. 光学设计一般有哪些步骤?
  7. “知感冒防流感”全民科普公益行9月10日走进中山
  8. Java版坦克大战游戏毕业设计
  9. dcdc芯片效率不高的原因_贴片DC/DC变换(稳压)ic主要故障与检修
  10. i2c-tools工具