关闭
搜索
搜索
本版
帖子
用户
热搜:
程序员
简洁模式
高级模式
用户组: 游客
消息
提醒
新听众
我关注的
帖子
道具
勋章
任务
设置
退出
请
登录
后使用快捷导航
没有帐号?
立即注册
设为首页
收藏本站
开启辅助访问
切换到窄版
登录
or
立即注册
快捷导航
搜索
首页
论坛
BBS
MCU单片机技术
程序员交流
Linux运维工程师在CentOS8/RHEL8上安装Ansible(自动化工具)
[复制链接]
作者:
你不防
版块:
›
嵌入式操作系统
›
linux
发布时间:
2020-1-14 00:26:44
1269
0
返回列表
你不防
当前离线
注册会员
注册会员, 积分 144, 距离下一级还需 56 积分
注册会员
注册会员, 积分 144, 距离下一级还需 56 积分
积分
144
发消息
楼主
电梯直达
你不防
发表于 2020-1-14 00:26:44
|
只看该作者
|
倒序浏览
|
阅读模式
Ansible 是给 Linux 系统管理员使用的出色自动化工具。它是一种开源配置工具,能让系统管理员可以从一个中心节点(即 Ansible 服务器)管理数百台服务器。将 Ansible 与 Puppet、Chef 和 Salt 等类似工具进行比较时,它是首选的配置工具,因为它不需要任何代理,并且可以工作在 SSH 和 python 上。
在本教程中,我们将学习如何在 CentOS 8 和 RHEL 8 系统上安装和使用 Ansble。
Ansible 实验环境信息:
最小化安装的 CentOS 8 / RHEL 8 服务器(192.168.1.10),且有互联网连接
两个 Ansible 节点 - Ubuntu 18.04 LTS (192.168.1.20) 和 CentOS 7 (192.168.1.30)
CentOS 8 上的 Ansible 安装步骤
Ansible 包不在 CentOS 8 默认的软件包仓库中。因此,我们需要执行以下命令启用 EPEL 仓库:
[root@linuxtechi ~]$ sudo dnf install http://dl.fedoraproject.org/pub/epel/epel-release-latest-8.noarch.rpm -y
启用 epel 仓库后,执行以下 dnf 命令安装 Ansible:
[root@linuxtechi ~]$ sudo dnf install ansible
上面命令的输出:
成功安装 Ansible 后,运行以下命令验证它的版本:
[root@linuxtechi ~]$ sudo ansible --version
上面的输出确认在 CentOS 8 上安装完成。
让我们看下 RHEL 8 系统。
RHEL 8 上的 Ansible 安装步骤
如果你有有效的 RHEL 8 订阅,请使用以下订阅管理器命令启用 Ansble 仓库:
[root@linuxtechi ~]$ sudo subscription-manager repos --enable ansible-2.8-for-rhel-8-x86_64-rpms
启用仓库后,执行以下 dnf 命令安装 Ansible:
[root@linuxtechi ~]$ sudo dnf install ansible -y
安装 Ansible 及其依赖包后,执行以下命令来验证它的版本:
[root@linuxtechi ~]$ sudo ansible --version
在 CentOS 8 / RHEL 8 上通过 pip3 安装 Ansible 的可选方法
如果你希望使用 pip(Python 的包管理器)安装 Ansible,请首先使用以下命令安装 pyhton3 和 python3-pip 包:
[root@linuxtechi ~]$ sudo dnf install python3 python3-pip -y
安装 python3 后,运行以下命令来验证它的版本:
[root@linuxtechi ~]$ python3 -V
Python 3.6.8
[root@linuxtechi ~]$
用下面的 pip3 命令安装 Ansible:
[root@linuxtechi ~]$ pip3 install ansible --user
输出:
上面的输出确认 Ansible 已成功使用 pip3 安装。让我们看下如何使用 Ansible。
如何使用 Ansible 自动化工具?
当我们使用 yum 或 dnf 命令安装 Ansible 时,它的配置文件、清单文件和角色目录会自动在 /etc/ansible 文件夹下创建。
让我们添加一个名称为 labservers 的组,并在 /etc/ansible/hosts 文件中给该组添加上述的 Ubuntu 18.04 和 CentOS 7 系统的 IP 地址:
[root@linuxtechi ~]$ sudo vi /etc/ansible/hosts
…
[labservers]
192.168.1.20
192.168.1.30
…
保存并退出文件。
更新清单文件(/etc/ansible/hosts)后,将用户的 ssh 公钥放到属于 labservers 组的远程系统。
让我们首先使用 ssh-keygen 命令生成本地用户的公钥和私钥:
[root@linuxtechi ~]$ ssh-keygen
现在使用以下命令在 Ansible 服务器及其客户端之间交换公钥:
[root@linuxtechi ~]$ ssh-copy-id root@linuxtechi
[root@linuxtechi ~]$ ssh-copy-id root@linuxtechi
现在,让我们尝试几个 Ansible 命令,首先使用 ping 模块验证 Ansible 服务器与客户端的连接:
[root@linuxtechi ~]$ ansible -m ping "labservers"
注意: 如果我们没有在上面的命令中指定清单文件,那么它将引用默认主机文件(即 /etc/ansible/hosts)。
输出:
让我们使用 Ansible shell 命令检查每个客户端的内核版本:
[root@linuxtechi ~]$ ansible -m command -a "uname -r" "labservers"
192.168.1.30 | CHANGED | rc=0 >>
4.15.0-20-generic
192.168.1.20 | CHANGED | rc=0 >>
3.10.0-327.el7.x86_64
[root@linuxtechi ~]$
使用以下命令列出清单文件中的所有主机:
[root@linuxtechi ~]$ ansible all -i /etc/ansible/hosts --list-hosts
hosts (4):
192.168.100.1
192.168.100.10
192.168.1.20
192.168.1.30
[root@linuxtechi ~]$
使用以下 Ansible 命令仅列出 labservers 组中的主机:
root@linuxtechi ~]$ ansible labservers -i /etc/ansible/hosts --list-hosts
hosts (2):
192.168.1.20
192.168.1.30
[root@linuxtechi ~]$
最后喜欢的同学点个关注、收藏、转发哦!
本帖子中包含更多资源
您需要
登录
才可以下载或查看,没有帐号?
立即注册
收藏
0
相关帖子
•
Shell:用户使用Linux的桥梁
•
Linux查看环境变量当前信息和查看命令
•
简单架设LINUXVPS服务器
•
超详细的PyCharm教程,必须收藏!
•
Linux操作系统应用试题
•
DBA常用Linux命令
•
Linux用户宝典:值得一用的5款远程桌面应用程序
•
SpringBoot搭建ELK,这才是正确看日志的方式!
•
Debian11.0“Bullseye”第2个候选版发布:基于Linux5.10内核
•
《Linux内核编码风格》官方手册最新中译本
回复
使用道具
举报
返回列表
高级模式
B
Color
Image
Link
Quote
Code
表情
@朋友
您需要登录后才可以回帖
登录
|
立即注册
本版积分规则
发表回复
回帖后跳转到最后一页
浏览过的版块
stm
ARM
招聘&找工作
硬件综合
生活交流*灌水区*工程师滋润生活*
IT业界资讯
vxWorks
快速回复
返回顶部
返回列表