ansible小试牛刀之使用ansible控制vagrant创建的三个主机以及两台阿里云服务器

下面的一切都是在rhel8环境上面运行的,需要作的准备如下:[往期博客]手把手教你在centos8或rhel8上面安装virtualbox

[往期博客]手把手教你vagrant的安装以及简单地使用

[往期博客]ansible入门之ansible安装与第一次连接
安装完vagrant之后我们就可以继续这篇博客了
首先我们要了解这样两个概念:
关于下面的公钥和私钥,可以见我这篇博客:[往期博客]ssh的两种登陆方式:密码登陆与免密登陆

·vagrant连接使用的是ssh,它的密钥已经生成过了,并且默认拒绝ssh密码连接的方式,所以我们使用密钥的方式就可以连接上(vagrant ssh会自动寻找密钥),但是直接用ssh命令的话就得指定密钥的位置,比较麻烦。所以我们下面采取先vagrant ssh连接,添加公钥,退出并配置ansible文件指定ssh私钥文件来使连接畅通。
·vagrant启动虚拟机时,采用的是以文件的方式去配置虚拟机的方法,这个文件就是Vagrantfile,这样我们就可以通过直接编辑Vagrantfile的方法来配置我们的虚拟机。

那么我们就正式开始:
看完上面的第二点,你就可以理解我下面这些操作的意义了:
首先我们得先建一个目录,用来存放虚拟机的相关文件:mkdir vm
由于我已经有这个目录了,这里就不再建立了。
进入目录,cd vm
创建一个新的Vagrantfile文件(注意一定得按这个大小写建立文件,要不vagrant up(启动虚拟机的命令)检测不出来)
Vagrant文件的内容如下:
这里要注意一下vm.vox_url那行,因为我本地下好了镜像,所以就直接指定本地的文件,如果您没有镜像,那就去掉那行,vagrant会自动从云上拉取镜像并运行。

Vagrant.configure("2") do |config|
  config.vm.define "vagrant1" do |vagrant1|
	vagrant1.vm.box = "centos8"
	vagrant1.vm.box_url = "/home/zephyr/Downloads/CentOS-8-Vagrant-8.3.2011-20201204.2.x86_64.vagrant-virtualbox.box"
	vagrant1.vm.network "forwarded_port", guest: 80, host: 8081
	vagrant1.vm.network "forwarded_port", guest: 443, host: 8443
  end
  config.vm.define "vagrant2" do |vagrant2|
	vagrant2.vm.box = "ubuntu"
	vagrant2.vm.box_url = "/home/zephyr/Downloads/focal-server-cloudimg-amd64-vagrant.box"
	vagrant2.vm.network "forwarded_port", guest: 80, host: 8082
	vagrant2.vm.network "forwarded_port", guest: 443, host: 8444
  end
  config.vm.define "vagrant3" do |vagrant3|
	vagrant3.vm.box = "centos8"
	vagrant3.vm.box_url = "/home/zephyr/Downloads/CentOS-8-Vagrant-8.3.2011-20201204.2.x86_64.vagrant-virtualbox.box"
	vagrant3.vm.network "forwarded_port", guest: 80, host: 8083
	vagrant3.vm.network "forwarded_port", guest: 443, host: 8445
  end
end

我们建立Vagrantfile文件:
在这里插入图片描述
输入上面的内容:
在这里插入图片描述
如果你想要让你的vim命令打开文件时显示行号,那么请移步这篇文章:【往期文章】如何让vim打开文件时默认显示行号
然后我们直接在Vagrant那个目录内使用vagrant up命令,静待配置完成:
在这里插入图片描述
这个原本会输出很长很长一串,但是由于我的虚拟机已经运行起来了,所以就没有那么多的输出了。
下面检查一下虚拟机的运行状态:
在这里插入图片描述
可以看到三台虚拟机都在运行中。
然后我们查看虚拟机的ssh信息:
在这里插入图片描述
在这里插入图片描述
从上面我们可以看到,vagrant创建的虚拟机的ip地址、端口号、私钥的位置,这些都是有用的信息。然后我们做服务器的免密登陆配置:
首先在本地生成ssh密钥对(一直回车就行):
在这里插入图片描述
接着我们把这个密钥对的公钥复制到远程的服务器上:(这一步的命令为ssh-copy-id 用户@ip地址)
在这里插入图片描述
这样就完成了ssh免密登陆的配置,令一台机子也这么配置。
然后我们打开ansible的配置文件:
在这里插入图片描述
在文件的末尾加上下面的内容:
在这里插入图片描述

zephyr ansible_host=47.97.250.202 ansible_port=22 ansible_ssh_user=root ansible_sudo_user=root 
hs ansible_host=47.93.86.191 ansible_port=22 ansible_ssh_user=root ansible_sudo_user=root 
vagrant1 ansible_host=127.0.0.1 ansible_port=2222 ansible_private_key_file=/home/zephyr/vm/.vagrant/machines/vagrant1/virtualbox/private_key ansible_ssh_user=root ansible_sudo_user=root
vagrant2 ansible_host=127.0.0.1 ansible_port=2200 ansible_private_key_file=/home/zephyr/vm/.vagrant/machines/vagrant2/virtualbox/private_key ansible_ssh_user=root ansible_sudo_user=root
vagrant3 ansible_host=127.0.0.1 ansible_port=2201 ansible_private_key_file=/home/zephyr/vm/.vagrant/machines/vagrant3/virtualbox/private_key ansible_ssh_user=root ansible_sudo_user=root
[server]
zephyr
vagrant1
vagrant3
[client]
hs
[ubuntu]
vagrant2

上面的中括号为分组的标识,也就是说我这里首先命名了五个主机,分别为zephyr、hs、vagrant1、vagrant2、vagrant3,然后把他们分为了server组、client组和ubuntu组。这里除了ubuntu组的vagrant2,其它的机子都是centos。
然后我们尝试用ansible连接一下:
在这里插入图片描述
在这里插入图片描述
可以看到,只有两个云服务器ping成功了,不过没有关系,这里的失败是因为没有把公钥添加到虚拟机的公钥文件中,我们来添加一下:
这里以vagrant2为例,其他的机子步骤都相同,首先我们先查看一下本机上的公钥:
在这里插入图片描述
这里的公钥复制一下,然后我们先连接到vagrant2上:
在这里插入图片描述
由于这个虚拟机不自带vim和nano编辑器,所以我们用管道来添加公钥,其实就是echo "公钥" >> ~/.ssh/authorlized_keys
在这里插入图片描述
然后我们看一下这个公钥有没有被添加进去:
在这里插入图片描述
然后切换到root用户:
在这里插入图片描述
进入root用户的.ssh目录:
在这里插入图片描述
然后把之前那个文件复制过来:
在这里插入图片描述
再检查一下:
在这里插入图片描述
最后ctrl+d两次,退出虚拟机,返回本机(其他的两个机子也这么配置),用ansible ping一下:
在这里插入图片描述
在这里插入图片描述
全绿,我们再来执行一个命令试试:
在这里插入图片描述
配置成功。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

许倾墨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值