Ansible在多台服务器上运行python脚本

使用 Ansible 在多台服务器上批量运行 Python 脚本是一种高效且可靠的方式。以下是具体的实现步骤和示例代码:


1. 准备工作

  • **安装 Ansible**:确保您的 Ansible 控制节点已安装 Ansible。如果没有安装,可以通过以下命令安装:

```bash

pip install ansible

```

  • **配置 Inventory 文件**:在 Ansible 控制节点上创建一个 `hosts.ini` 文件,列出需要运行脚本的目标服务器:

```ini

servers

server1 ansible_host=192.168.1.10 ansible_user=root

server2 ansible_host=192.168.1.11 ansible_user=root

server3 ansible_host=192.168.1.12 ansible_user=root

```

根据实际环境修改 IP 地址和用户名。

  • **编写 Python 脚本**:将您的 Python 脚本(例如 `script.py`)上传到 Ansible 控制节点,或者确保目标服务器上已存在该脚本。

2. 创建 Ansible Playbook

创建一个 YAML 文件(例如 `run_python.yml`),定义 Ansible 任务以批量运行 Python 脚本:

```yaml


  • name: Run Python script on remote servers

hosts: servers

become: yes

tasks:

  • name: Ensure Python is installed

apt:

name: python3

state: present

when: ansible_os_family == 'Debian'

  • name: Ensure Python3 is installed

yum:

name: python3

state: present

when: ansible_os_family == 'RedHat'

  • name: Copy Python script to remote server

copy:

src: script.py

dest: /tmp/script.py

mode: '0755'

  • name: Execute Python script

command: python3 /tmp/script.py

```

  • **解释**:
  1. **Ensure Python is installed**:确保目标服务器上安装了 Python(根据不同的 Linux 发行版使用不同的包管理工具)。

  2. **Copy Python script to remote server**:将 Python 脚本从控制节点复制到目标服务器的 `/tmp` 目录。

  3. **Execute Python script**:在目标服务器上运行 Python 脚本。


3. 运行 Ansible Playbook

在 Ansible 控制节点上运行以下命令,执行 Playbook:

```bash

ansible-playbook run_python.yml -i hosts.ini

```

  • **解释**:

  • `-i hosts.ini`:指定 Inventory 文件路径。

  • `run_python.yml`:Playbook 文件名。

运行后,Ansible 将依次连接到每个目标服务器,执行上述任务,包括安装 Python(如果尚未安装)、复制脚本并运行脚本。


4. 注意事项

  1. **Python 版本**:确保目标服务器上安装了 Python 3(或其他您脚本所需的版本),并根据 Playbook 中的条件语句适配不同的 Linux 发行版。

  2. **脚本路径**:确保脚本路径正确,或者修改 Playbook 中的 `dest` 和 `command` 字段。

  3. **权限问题**:确保目标服务器上的 `/tmp` 目录对执行用户(通常是 root)有写权限。

  4. **日志查看**:运行 Playbook 后,可以通过命令 `ansible-playbook run_python.yml -i hosts.ini --start-at-task="Execute Python script"` 查看任务执行日志。


通过以上步骤,您可以轻松使用 Ansible 在多台服务器上批量运行 Python 脚本。如果有其他问题或需要进一步帮助,请随时联系!

相关推荐
小辰记事本2 小时前
从零读懂RoCEv2数据包构造:从WQE到线缆上的完整旅程
服务器·网络·网络协议·rdma
曲幽2 小时前
我用了FastApiAdmin后,连夜把踩过的坑都整理出来了
redis·python·postgresql·vue3·fastapi·web·sqlalchemy·admin·fastapiadmin
前端若水4 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
涛声依旧-底层原理研究所5 小时前
残差连接与层归一化通俗易懂的详解
人工智能·python·神经网络·transformer
csdn_aspnet5 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
fantasy_arch5 小时前
pytorch人脸匹配模型
人工智能·pytorch·python
熊猫_豆豆5 小时前
广义相对论水星近日点进动完整详细数学推导
python·天体·广义相对论
江公望5 小时前
Ubuntu htop命令,10分钟讲清楚
linux·服务器
哎呦,帅小伙哦5 小时前
Linux 时间:从原子钟到 clock_gettime 的每一面
linux·运维·服务器
web3.08889995 小时前
1688 图搜接口(item_search_img / 拍立淘) 接入方法
开发语言·python