星途物语 星途物语
首页
  • 随手记录
  • 故障处理
  • Nginx
  • MySQL
  • Ansible
  • Nexus
  • Tomcat
  • Docker
  • Zabbix
  • Prometheus
  • Git
  • GitLab
  • Jenkins
  • Kubernetes
  • Shell
  • Python
  • 圈圈空间
  • 做饭这件事
收藏站点
留言板
归档
GitHub (opens new window)

星途物语

尚记时,记之
首页
  • 随手记录
  • 故障处理
  • Nginx
  • MySQL
  • Ansible
  • Nexus
  • Tomcat
  • Docker
  • Zabbix
  • Prometheus
  • Git
  • GitLab
  • Jenkins
  • Kubernetes
  • Shell
  • Python
  • 圈圈空间
  • 做饭这件事
收藏站点
留言板
归档
GitHub (opens new window)
  • 随手记录

    • QPS优化记录
    • 阿里云SLB演示
    • DDOS预防
    • Linux内核优化
    • rsync同步守护进程
    • NFS文件同步
    • Tomcat升级
    • 编译安装mysql后添加到systemd管理
    • 防火墙笔记
    • python自动化巡检服务器
      • 1.安装python依赖包
      • 2.代码编写
      • 3.打包exe
  • 故障处理

    • 处理防MIME攻击后出现的问题解决
  • MySQL学习笔记

    • MySQL5.7安装
    • MySQL常用操作语句
    • MySQL主从架构实施
    • MySQL主主架构实施
    • MySQL MHA高可用实施
    • MyCat读写分离
    • MySQL创建用户时的授权
    • MySQL备份
    • MySQL通配符
  • Nginx学习笔记

    • 状态码含义
    • 匹配优先级
    • Nginx常用操作
    • 添加第三方模块
    • 关于路径匹配
    • 转发和重写
    • 内置变量
    • Nginx配置文件结构
  • Tomcat学习笔记

    • 部署Tomcat
    • 修改发布目录
    • Tomcat调优
  • Redis学习笔记

    • 通过 tar.gz 包安装部署 redis
    • redis 配置文件
    • 哨兵集群
    • redis常用命令
    • 虚拟机安装 redis.tar.gz 遇到的问题
  • Ansible学习笔记

    • 部署和使用 ansible
    • ansible 自带的密码认证参数
    • 批量免密操作:批量分发公钥
    • 配置主机清单
    • ansible 小知识
    • 模块介绍
    • 剧本
    • 一键部署 rsync 环境
    • 批量安装一个tomcat
    • 批量安装一个nginx
    • 批量安装 zabbix-agent
  • Zabbix学习笔记

    • 部署 zabbix 服务端、客户端
    • 自定义监控
    • 触发器
    • 监控项类型
    • 简单检查模式
    • zabbix web 界面结构信息
    • 邮件报警
    • 微信报警
    • snmp 监控网络设备
    • 部署 zabbix 服务端、客户端
    • jmx 监控 java 应用
    • ipmi 监控硬件
    • 自动化注册
    • 监控项的主要项和相关项
    • percona 监控 mysql
  • Git学习笔记

    • 配置 git
    • 常用命令
  • GitLab学习笔记

    • 环境准备
    • 安装 gitlab
    • gitlab 忘记 root 管理员密码的处理办法
  • Jenkins学习笔记

    • 安装部署
    • jenkins 使用脚本完成项目构建
    • jenkins 自动构建最新项目
    • 将 jenkins 自动部署的结果返回给 gitlab
    • jenkins 上线 java 项目
    • jenkins pipeline
  • Docker学习笔记

    • 安装 docker
    • 配置 docker 源
    • docker 中的常见名词
    • 镜像管理命令
    • 容器管理命令
    • 创建容器
    • 数据卷
    • docker network
    • 搭建 LNMP
    • Dockerfile
    • Dockerfile 搭建 tomcat
    • docker 镜像磁盘扩容
    • docker composer
    • Harbor 私有镜像仓库
    • docker 面试题
    • docker desktop 运行时与虚拟机冲突
    • docker离线安装
  • Nexus学习笔记
  • Prometheus学习笔记

    • 核心组件
    • 工作原理
    • 安装和配置
    • 启动 Prometheus
    • PromQL 使用
    • 数据模型
    • Exporter
    • 演示服务
    • Grafana 数据可视化
    • Prometheus 告警
  • Kubernetes学习笔记

    • K8S的介绍
    • K8S集群环境的搭建
    • K8S资源管理
    • K8S的实战入门
  • 运维
  • 随手记录
星途物语
2025-04-28
目录

python自动化巡检服务器

# python自动化巡检服务器

需求:通过 SSH 远程连接到服务器执行命令收集结果,进行自动化多主机巡检

# 1.安装python依赖包

pip install paramiko

pip install pyinstaller

# 2.代码编写

import os
import paramiko
from datetime import datetime

# 定义服务器列表
servers = [
    {"hostname": "10.0.0.50", "port": 22, "username": "zzl", "password": "J@LE*_UOWK95upDH"},
    {"hostname": "10.0.0.51", "port": 22, "username": "zzl", "password": "%@w(264EHi91XRnB"},
    {"hostname": "10.0.0.52", "port": 22, "username": "zzl", "password": "5EPAmZeF9!7&yncT"},
    # 添加更多服务器...
]

# 定义检测命令
commands = {
    "firewall": "systemctl status iptables || echo 'iptables service not found'",  # 防火墙检测命令
    "disk": "df -h",  # 磁盘检测命令
    "memory": "free -h",  # 内存检测命令
    "cpu": "top -bn1 | grep 'Cpu(s)'",  # CPU 检测命令
    "ssh_status": "systemctl status sshd || echo 'SSH service not found'",  # SSH状态检测
    "uptime": "uptime",  # 系统负载检测
    "user_activity": "last",  # 用户活动和登录记录检测
    "system_time": "timedatectl",  # 系统时间检测
    "network_connections": "netstat -tunpl",  # 网络连接检测
    "jar_processes": "ps aux | grep jar | grep -v grep | grep -v 'sa-agent'"  # 检测运行中的jar进程
}

def ssh_execute_and_save_output(servers, commands):
    try:
        # 动态生成日期目录
        current_date = datetime.now()
        year = current_date.strftime("%Y")  # 年份,如 "2025"
        month = current_date.strftime("%m")  # 月份,如 "04"
        day = current_date.strftime("%d")    # 日期,如 "24"

        # 构造目标目录路径
        output_dir = os.path.join(os.getcwd(), year, month, day)
        os.makedirs(output_dir, exist_ok=True)

        # 初始化文件句柄
        file_handles = {}
        for item in commands.keys():
            file_name = f"{item}_检测.txt"
            file_path = os.path.join(output_dir, file_name)
            file_handles[item] = open(file_path, "w", encoding="utf-8")

        # 遍历每个服务器
        for server in servers:
            hostname = server["hostname"]
            port = server["port"]
            username = server["username"]
            password = server["password"]

            print(f"正在连接到服务器: {hostname}")
            ssh = paramiko.SSHClient()
            ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
            ssh.connect(hostname, port=port, username=username, password=password)

            # 遍历每个检测项
            for item, command in commands.items():
                print(f"在服务器 {hostname} 上执行命令: {command}")
                stdin, stdout, stderr = ssh.exec_command(command)
                output = stdout.read().decode('utf-8')
                error = stderr.read().decode('utf-8')

                # 写入文件
                file_handles[item].write(f"{hostname}\n")
                if output:
                    file_handles[item].write(f"{output}\n")
                if error:
                    file_handles[item].write(f"错误输出:\n{error}\n")
                file_handles[item].write("\n" + "-" * 50 + "\n")  # 分隔线

            # 关闭当前服务器连接
            ssh.close()
            print(f"完成服务器 {hostname} 的检测\n")

        # 关闭所有文件句柄
        for file in file_handles.values():
            file.close()

        print(f"所有检测已完成,结果保存在目录: {output_dir}")

    except Exception as e:
        print(f"发生错误: {e}")

# 示例调用
if __name__ == "__main__":
    ssh_execute_and_save_output(servers, commands)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88

执行结果展示

image-20250428112429983

# 3.打包exe

将代码打包exe文件,脱离python环境也能运行

pyinstaller --onefile demo2_ssh.py
1
image-20250428112553180 image-20250428112605579
#随手记录#python
防火墙笔记
处理防MIME攻击后出现的问题解决

← 防火墙笔记 处理防MIME攻击后出现的问题解决→

Theme by Vdoing | Copyright © 2025-2025 | 鄂ICP备2024086820号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式