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 脚本。如果有其他问题或需要进一步帮助,请随时联系!

相关推荐
invicinble4 小时前
对linux形成认识
linux·运维·服务器
冷雨夜中漫步4 小时前
Python快速入门(6)——for/if/while语句
开发语言·经验分享·笔记·python
技术路上的探险家4 小时前
8 卡 V100 服务器:基于 vLLM 的 Qwen 大模型高效部署实战
运维·服务器·语言模型
郝学胜-神的一滴5 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
百锦再5 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
半桔5 小时前
【IO多路转接】高并发服务器实战:Reactor 框架与 Epoll 机制的封装与设计逻辑
linux·运维·服务器·c++·io
绵绵细雨中的乡音5 小时前
深入理解 ET 与 LT 模式及其在 Reactor 模型中的应用
服务器·网络·php
HABuo5 小时前
【linux文件系统】磁盘结构&文件系统详谈
linux·运维·服务器·c语言·c++·ubuntu·centos
Howrun7776 小时前
关于Linux服务器的协作问题
linux·运维·服务器
喵手6 小时前
Python爬虫实战:旅游数据采集实战 - 携程&去哪儿酒店机票价格监控完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集结果csv导出·旅游数据采集·携程/去哪儿酒店机票价格监控