Ansible是一种自动化工具,可用于批量部署服务和配置管理。它使用SSH进行连接,并通过YAML文件描述操作,可以快速轻松地在大规模部署上部署和管理软件服务。在本文中,我们将探讨如何使用Ansible进行批量部署nginx。
准备工作
在开始使用Ansible之前,您需要在本地或远程机器上安装Ansible。您还需要在运行Ansible的机器上安装Python和netaddr模块。
安装 Ansible:
sudo apt update
sudo apt install ansible
安装 Python 和 netaddr:
sudo apt install python-pip
sudo pip install netaddr
实际环境
我们将在4个服务器上执行操作,其中1个作为Ansible Master,另外3台服务器用于部署nginx。它们的IP地址如下:
192.168.0.1 - Ansible Master
192.168.0.2 - Server 1
192.168.0.3 - Server 2
192.168.0.4 - Server 3
SSH凭证
在运行Ansible操作之前,需要确保您可以通过SSH连接到目标服务器,而不需要手动输入密码。为此,您需要在Ansible Master上为每个服务器创建一个SSH密钥对,并将公钥添加到目标服务器的authorized_keys文件中。
示例代码:
创建一个SSH密钥对:(在Ansible Master中操作)
ssh-keygen -t rsa
将公钥添加到目标服务器的authorized_keys文件中:(在Ansible Master中操作)
ssh-copy-id user@192.168.0.2
ssh-copy-id user@192.168.0.3
ssh-copy-id user@192.168.0.4
Ansible Inventory
使用Ansible进行批量操作时,需要定义一个清单文件,其中包含要操作的所有目标服务器的详细信息。清单文件遵循INI格式,并将运行的每个服务器指定为[section]:
[web]
192.168.0.2
192.168.0.3
192.168.0.4
[web:vars]
ansible_user=user
在上面的清单文件中,“web”是变量,其中包含三个不同的服务器。注意,您可以为清单文件中的组定义变量,这些变