百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

python快速巡检百台linux系统,并汇总到运维机生成word报告

ahcoder 2025-02-14 22:10 13 浏览

要实现自动化巡检100台Linux系统,并将巡检结果统一发送到运维机生成Word报告,可以采用以下方案:

---

### 1. 整体架构

1. **分布式巡检**:

- 在每台被巡检的Linux系统上运行一个巡检脚本,收集本地系统信息。

- 将巡检结果发送到运维机(集中管理服务器)。

2. **集中处理**:

- 运维机接收所有巡检结果,汇总并生成Word报告。

3. **通信方式**:

- 使用SSH或HTTP API将巡检结果发送到运维机。

---

### 2. 实现步骤

#### 2.1 在被巡检机器上运行巡检脚本

每台Linux系统上运行一个Python脚本,收集本地系统信息,并将结果发送到运维机。

```python

# local_inspection.py

import psutil

import requests

import json

from datetime import datetime

# 运维机的API地址

SERVER_URL = "http://your-ops-server-ip:5000/report"

# 收集系统信息

def collect_system_info():

info = {

"hostname": psutil.users()[0].name, # 主机名

"cpu_usage": psutil.cpu_percent(interval=1), # CPU使用率

"memory_usage": psutil.virtual_memory().percent, # 内存使用率

"disk_usage": psutil.disk_usage('/').percent, # 磁盘使用率

"network_sent": psutil.net_io_counters().bytes_sent, # 网络发送字节数

"network_recv": psutil.net_io_counters().bytes_recv, # 网络接收字节数

"load_avg": psutil.getloadavg(), # 系统负载

"timestamp": datetime.now().strftime("%Y-%m-%d %H:%M:%S") # 巡检时间

}

return info

# 发送巡检结果到运维机

def send_report(info):

try:

response = requests.post(SERVER_URL, json=info)

if response.status_code == 200:

print("巡检结果发送成功")

else:

print(f"发送失败: {response.status_code}")

except Exception as e:

print(f"发送失败: {e}")

if __name__ == "__main__":

system_info = collect_system_info()

send_report(system_info)

```

---

#### 2.2 在运维机上运行接收服务

运维机上运行一个Flask服务,接收所有被巡检机器的报告,并保存到本地。

```python

# server.py

from flask import Flask, request, jsonify

from datetime import datetime

import json

app = Flask(__name__)

# 存储所有巡检结果

reports = []

# 接收巡检结果的API

@app.route('/report', methods=['POST'])

def receive_report():

report = request.json

reports.append(report)

print(f"收到来自 {report['hostname']} 的巡检报告")

return jsonify({"status": "success"}), 200

# 生成Word报告

def generate_word_report():

from docx import Document

doc = Document()

doc.add_heading('Linux系统巡检汇总报告', 0)

for report in reports:

doc.add_heading(f"主机: {report['hostname']}", level=1)

doc.add_paragraph(f"巡检时间: {report['timestamp']}")

doc.add_paragraph(f"CPU使用率: {report['cpu_usage']}%")

doc.add_paragraph(f"内存使用率: {report['memory_usage']}%")

doc.add_paragraph(f"磁盘使用率: {report['disk_usage']}%")

doc.add_paragraph(f"网络发送字节数: {report['network_sent']}")

doc.add_paragraph(f"网络接收字节数: {report['network_recv']}")

doc.add_paragraph(f"系统负载: {report['load_avg']}")

doc.add_paragraph("\n")

report_filename = f"System_Inspection_Report_{datetime.now().strftime('%Y%m%d_%H%M%S')}.docx"

doc.save(report_filename)

print(f"Word报告已生成: {report_filename}")

if __name__ == "__main__":

app.run(host="0.0.0.0", port=5000)

```

---

#### 2.3 定时任务

1. **在被巡检机器上**:

- 使用`cron`定时运行`local_inspection.py`,例如每小时执行一次:

```bash

0 * * * * /usr/bin/python3 /path/to/local_inspection.py

```

2. **在运维机上**:

- 定时运行`generate_word_report`函数,生成汇总报告。例如每天凌晨1点生成报告:

```bash

0 1 * * * /usr/bin/python3 /path/to/server.py --generate-report

```

---

#### 2.4 扩展功能

1. **异常报警**:

- 在`local_inspection.py`中,如果某项指标超过阈值(如CPU使用率>90%),可以发送报警信息(邮件、短信等)。

```python

def send_alert(message):

# 使用邮件或短信API发送报警

print(f"报警: {message}")

```

2. **更多巡检项**:

- 检查服务状态、日志文件、文件系统完整性等。

```python

def check_services():

services = ["nginx", "mysql", "docker"]

for service in services:

status = subprocess.run(['systemctl', 'is-active', service], capture_output=True, text=True)

if status.stdout.strip() != 'active':

send_alert(f"服务 {service} 未运行")

```

3. **数据持久化**:

- 将巡检结果保存到数据库(如MySQL、MongoDB),便于后续分析和查询。

---

### 3. 部署与运行

1. **在被巡检机器上**:

- 安装Python和依赖库:

```bash

pip install psutil requests

```

- 部署`local_inspection.py`并配置定时任务。

2. **在运维机上**:

- 安装Python和依赖库:

```bash

pip install flask python-docx

```

- 运行`server.py`:

```bash

python3 server.py

```

---

### 4. 报告示例

生成的Word报告内容如下:

```

Linux系统巡检汇总报告

主机: server1

巡检时间: 2025-02-04 14:30:00

CPU使用率: 45.2%

内存使用率: 60.3%

磁盘使用率: 55.8%

网络发送字节数: 102345678

网络接收字节数: 987654321

系统负载: (0.5, 0.4, 0.3)

主机: server2

巡检时间: 2025-02-04 14:30:00

CPU使用率: 90.5%

内存使用率: 85.2%

磁盘使用率: 70.1%

网络发送字节数: 123456789

网络接收字节数: 987654321

系统负载: (1.2, 1.1, 1.0)

```

---

通过以上方案,你可以实现100台Linux系统的自动化巡检,并生成统一的Word报告,满足运维需求。

相关推荐

Linux ntp时钟同步问题(linux ntp同步命令)

有时候,操作系统会报linux的ntp时钟错误。从时钟源同步时间超时。我查看了一下ntp的时钟源,发现执行ntpq-p显示超时。执行nslookup时钟服务器域名,发现可以正常解析。执行了n...

linux服务器同步利器Rsync全介绍(付脚本)

1、认识Rsync(remotesynchronize)是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件。Rsync使用所谓的“Rsync算法”来使本地和远程两个主机之间的文件...

如何使用Rsync同步两个网站服务器的内容

本头条号每天坚持更新原创干货技术文章,欢迎关注本头条号"Linux学习教程",公众号名称“Linux入门学习教程"。如需学习视频,请复制以下信息到手机浏览器或电脑浏览器上:zc...

Linux TB级小文件同步备份解决方案

在某些电子档案存储的业务系统下,按照业务场景要求,需要将产生的所有电子影像资料永久存储,并支持备份;因为“钞能力”等原因,一般备份存储只有一个节点(即:一个备份存储服务器);这样就要求研发工程师,不...

CentOS7下使用Lsyncd实现文件实时同步

Lsyncd简单介绍Lsyncd使用文件系统事件接口(inotify或fsevents)来监视本地文件和目录的更改。Lsyncd在几秒钟内将这些文件事件整理核对后,然后生成一个或多个进程以将更...

如何手动同步Linux系统时间并与互联网时间保持同步?

在Linux系统中,正确的时间同步对于许多任务都是至关重要的。一些关键应用程序可能需要准确的时间戳才能正常工作,而一些安全功能也需要确保所有服务器的时间都是准确的。NTP服务可以自动同步系统时间和互...

Linux服务器Rsync定时同步一键化配置指南

1、主从服务器同时安装rsyncopenssh-clientaptupdate&&aptinstall-yrsyncopenssh-client2、主服务器安装好后输入以下命令生成密钥...

Linux系统如何使用NTPDATE命令设置时间同步

简介:咱们在使用Linux系统的时候,常常能发现用了一阵子之后,Linux系统的时间就对不上了。已经知道的情况是,安装Linux的时候选的时区是Asia/Shanghai,可这系统运行了一...

开源的Linux文件同步工具有哪些?(linux 文件夹 同步)

Linux系统之间经常需要文件同步,一个好的文件同步工具省时省力,这里介绍几款开源的Linux文件同步工具1.rsync:rsync是Linux上一个功能强大的命令行工具,可以在不同的服务器之间同...

Linux 系统使用 rsync + inotify 实现文件实时同步

Linux系统使用rsync+inotify实现文件实时同步简介inotify监控文件的变化后通知rsync进行文件的同步#配置免密登录ssh-keygen-trsaca...

Linux 远程数据同步工具详解(linux远程同步命令)

一、简介1认识Rsync(remotesynchronize)是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件。Rsync使用所谓的“Rsync算法”来使本地和远程两个主机之...

构建基于 Linux 的 NTP 时间同步集群与时间安全防护实战指南

一、为什么时间同步对系统如此重要?在分布式系统、数据库复制、消息队列、审计日志、安全认证(如Kerberos)、容器编排等场景中,系统时间一致性是保障正确性与安全性的基础。一旦服务器间时间漂移,可能...

每日Linux学习:同步备份工具 rsync

rsync是一个用于高效同步文件和目录的工具。它通过仅传输变化的部分(增量传输)来节省时间和带宽,支持本地同步、远程同步(通过SSH),还能保留文件原有权限、时间戳等属性。本文通过几个常用的实例来...

Chromixium OS 1.0发布 基于Ubuntu发行版

Chromixium项目宣布chromixiumOS1发布,一款基于Ubuntu的Linux分支,chromixiumOS试图重新打造一款外观和感觉与ChromeOS相似的完...

iOS8.0.X~iOS8.1完美越狱!盘古团队出品

【巴士速递·移动情报站】最新消息,iOS8.1越狱了!!此次越狱依旧是iOS7时代我国的大神盘古团队带来的,而该次越狱支持最新的iPhone6、iPhone6Plus、iPadAir2和iPad...