Python 之 日志巡检脚本

news2024/10/5 11:07:20

脚本说明

使用Paramiko库进行SSH连接的自动化脚本,用于检查、配置和排除设备故障。说明如下:

  1. 导入所需的库:paramiko、json、logging和concurrent.futures。
  2. 定义配置文件路径(devices.json)和日志文件路径(automation.log)。
  3. 设置日志级别为INFO。
  4. 定义一个函数read_config(),用于读取设备信息配置文件。如果配置文件不存在或解析错误,将记录错误日志并返回None。
  5. 定义一个函数connect_device(device),用于连接到指定的设备。如果连接失败,将记录错误日志并返回None。
  6. 定义一个函数execute_command(client, command),用于在已连接的设备上执行命令。如果命令执行出错,将记录错误日志并返回None。
  7. 定义一个函数check_device_status(device),用于检查设备的状态。如果设备状态正常,将记录信息日志并输出结果。
  8. 定义一个函数configure_device(device),用于配置指定的设备。如果配置成功,将记录信息日志并输出结果。
  9. 定义一个函数troubleshoot_device(device),用于排除设备的故障。如果故障排除成功,将记录信息日志并输出结果。
  10. 定义主函数main(),用于执行上述操作。首先调用read_config()函数读取设备信息配置文件,然后使用多线程并发地检查、配置和排除设备的故障。最后记录脚本执行完毕的信息日志。
  11. 如果脚本作为主程序运行,则调用main()函数执行上述操作。

首先读取设备信息配置文件,然后使用多线程并发地检查、配置和排除设备的故障。

脚本示例

import paramiko
import json
import logging
import concurrent.futures


# 配置文件路径
CONFIG_FILE = 'devices.json'


#日志配置
LOG_FILE = 'automation.log'
LOG_LEVEL = logging.INFO


# 连接超时时间( 秒) 
CONNECT_TIMEOUT = 10


# 配置日志
logging.basicConfig(filename = LOG_FILE, level = LOG_LEVEL)


# 读取设备信息配置文件
def read_config():
    try:
        with open(CONFIG_FILE, 'r') as file:
            config = json.load(file)
            return config
    except FileNotFoundError:
        logging.error(f '配置文件 {CONFIG_FILE} 未找到')
    except json.JSONDecodeError:
        logging.error(f '配置文件 {CONFIG_FILE} 解析错误')


    return None


# 连接设备
def connect_device(device):
    client = paramiko.SSHClient()
    client.set_missing_host_key_policy(paramiko.AutoAddPolicy())


    try:
        client.connect(
            hostname = device['host'], 
            username = device['username'], 
            key_filename = device['key_filename'], 
            timeout = CONNECT_TIMEOUT
        )
        return client
    except paramiko.AuthenticationException: 
        logging.error(f "无法连接设备 {device['host']}: 身份验证失败")
    except paramiko.SSHException as e: 
        logging.error(f "无法连接设备 {device['host']}: {str(e)}")
    except Exception as e:
        logging.error(f "无法连接设备 {device['host']}: {str(e)}")


    return None


# 执行命令
def execute_command(client, command):
    try:
        stdin, stdout, stderr = client.exec_command(command, timeout = CONNECT_TIMEOUT)
        output = stdout.read().decode('utf-8')
        error = stderr.read().decode('utf-8')
        client.close()


        if error:
            logging.error(f "命令执行出错: {error}")
            return None


        return output.strip()
    except Exception as e:
        logging.error(f "命令执行出错: {str(e)}")
        return None


# 检查设备状态
def check_device_status(device):
    client = connect_device(device)


    if client:
        output = execute_command(client, 'show interfaces')
        if output:
            logging.info(f "设备 {device['host']} 状态正常")
            logging.info(output)


# 配置设备
def configure_device(device):
    client = connect_device(device)


    if client:
        config_commands = [
            'interface eth0', 
            'ip address 192.168.1.1 255.255.255.0', 
            'no shutdown'
        ]


        for command in config_commands:
            execute_command(client, command)


        logging.info(f "设备 {device['host']} 配置已更新")


# 故障排除
def troubleshoot_device(device):
    client = connect_device(device)


    if client:
        output = execute_command(client, 'show logs')
        if output:
            logging.info(f "设备 {device['host']} 故障排除日志:")
            logging.info(output)


# 主函数
def main():
    config = read_config()


    if config:
        with concurrent.futures.ThreadPoolExecutor() as executor:
            futures = []
            for device in config['devices']:
                logging.info(f "正在检查设备 {device['host']} 的状态...")
                futures.append(executor.submit(check_device_status, device))


            for future in concurrent.futures.as_completed(futures):
                future.result()


        with concurrent.futures.ThreadPoolExecutor() as executor:
            futures = []
            for device in config['devices']:
                logging.info(f "正在配置设备 {device['host']}...")
                futures.append(executor.submit(configure_device, device))


            for future in concurrent.futures.as_completed(futures):
                future.result()


        with concurrent.futures.ThreadPoolExecutor() as executor:
            futures = []
            for device in config['devices']:
                logging.info(f "正在进行故障排除...")
                futures.append(executor.submit(troubleshoot_device, device))


            for future in concurrent.futures.as_completed(futures):
                future.result()


    logging.info("脚本执行完毕")


if __name__ == '__main__':
    main()

来自: 学习Python 之 日志巡检脚本icon-default.png?t=N7T8https://mp.weixin.qq.com/s?__biz=Mzk0NTQ3OTk3MQ==&mid=2247487526&idx=1&sn=aa64a64703a14f4c5f1a9527e8fe5f3c&chksm=c315986af462117c3235616370efdf3a6e7b88489b1b090a7ba8ac85ab17956bd2cf53be880d&token=355315523&lang=zh_CN#rd

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1695810.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Unity射击游戏开发教程:(26)创建绕圈跑的效果

unity游戏 在本文中,我将介绍如何为敌人创建圆周运动。gif 中显示的确切行为是敌人沿着屏幕向下移动,直到到达某个点,一旦到达该点,它就会绕圈移动。

c语言:摆脱对指针的恐惧【4】

在上一期指针我们讲到了二级指针是的作用是存放一级指针的地址,还讲了指针数组是一个可以存放若干个指针变量的数组,这里我们再复习一下,下面指针数组是什么意思? int* arr1[10]; //整形指针的数组 char *arr2[4]; //一级字符指针…

JavaSE——集合框架二(1/6)-前置知识-可变参数、Collections工具类

目录 可变参数 Collections工具类 Collections的常用静态方法 实例演示 可变参数 可变参数 就是一种特殊形参,定义在方法、构造器的形参列表里,格式是:数据类型...参数名称 可变参数的特点和好处 特点:可以不传数据给它&am…

常用API(正则表达式、爬取、捕获分组和非捕获分组 )

1、正则表达式 练习——先爽一下正则表达式 正则表达式可以校验字符串是否满足一定的规则,并用来校验数据格式的合法性。 需求:假如现在要求校验一个qq号码是否正确。 规则:6位及20位之内,0不能在开头,必须全部是数字…

超详细的前后端实战项目(Spring系列加上vue3)前端篇+后端篇(三)(一步步实现+源码)

好了,兄弟们,继昨天的项目之后,开始继续敲前端代码,完成前端部分(今天应该能把前端大概完成开启后端部分了) 昨天补充了一下登录界面加上了文章管理界面和用户个人中心界面 完善用户个人中心界面 修改一…

【被小学生教育的一天】

今日文章有感,记博主文章📝,分享与感触。原文如下, 今天让小学生给我上了一课啊,今天去一所学校就实地考察感触特别深啊,就我从里面抽取一小块啊,给大家看一下,这个学校的教学规划&a…

STM32中断编程入门

文章目录 一、 理论部分1.中断系统2.中断执行流程3.NVIC的基本结构4.EXTI介绍5.AFIO复用IO口 二、实验目的:学习stm32中断原理和开发编程方法。使用标准完成以下任务:(一)实验一 开关控制LED的亮灭1.代码部分2.运行结果 &#xff…

SpringBoot+Vue开发记录(七)-- 跨域文件与Restful风格

本篇文章的主要内容是关于项目的跨域配置和给项目添加restful风格接口。 重点是文件粘贴 文章目录 一、 跨域二、Restful风格1. 什么是restful风格?2. 项目文件结构3. 新建文件4. 在Controller中进行修改 一、 跨域 跨域问题暂时也就那样,解决方法就是…

【搜索方法推荐】高效信息检索方法和实用网站推荐

博主未授权任何人或组织机构转载博主任何原创文章,感谢各位对原创的支持! 博主链接 本人就职于国际知名终端厂商,负责modem芯片研发。 在5G早期负责终端数据业务层、核心网相关的开发工作,目前牵头6G算力网络技术标准研究。 博客…

AI视频教程下载:ChatGPT API、HTML、CSS 和 JS开发AI聊天机器人

在课程中,你将开启一段令人兴奋的聊天机器人开发之旅,并装备自己创建智能对话代理所需的技能和知识。 利用 ChatGPT API、HTML、CSS 和 JavaScript 的强大功能,你将学习如何设计和构建吸引用户并提供个性化体验的聊天机器人界面。深入探讨聊天机器人开发的基础知识,了解对话设…

【Docker学习】深入研究命令docker exec

使用docker的过程中,我们会有多重情况需要访问容器。比如希望直接进入MySql容器执行命令,或是希望查看容器环境,进行某些操作或访问。这时就会用到这个命令:docker exec。 命令: docker container exec 描述&#x…

AI网络爬虫-自动获取百度实时热搜榜

工作任务和目标&#xff1a;自动获取百度实时热搜榜的标题和热搜指数 标题&#xff1a;<div class"c-single-text-ellipsis"> 东部战区台岛战巡演练模拟动画 <!--48--></div> <div class"hot-index_1Bl1a"> 4946724 </div> …

OpenAI撤回有争议的决定:终止永久性非贬损协议

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

HTML静态网页成品作业(HTML+CSS+JS)——心理健康教育介绍网页(4个页面)

&#x1f389;不定期分享源码&#xff0c;关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 &#x1f3f7;️本套采用HTMLCSS&#xff0c;使用Javacsript代码使用下拉菜单的实现以及首页图片的轮播&#xff0c…

ESP32烧录AT固件并进行MQTT通讯

首先下载AT固件 发布的固件 - ESP32 - — ESP-AT 用户指南 latest 文档 下载烧录工具 下载指导 - ESP32 - — ESP-AT 用户指南 latest 文档 烧录后注意usb的串口是不能发AT指令的 需要用16和17脚 用AT指令确认OK后连WIFI ATCWMODE1 //设置客户端模式 ATCWLAP …

CV大作业28期-使用TensorFlow快速实现图像风格迁移系统

使用TensorFlow快速实现图像风格迁移系统 资源地址&#xff1a;待更新 视频地址&#xff1a;待更新 随着GPT的横空出世&#xff0c;生成式网络也越来越活&#xff0c;现在的大语言模型除了能回答文字上面的内容&#xff0c;并且在图像和视频创作中也表现除了巨大的潜力&#xf…

Websocket助手

功能介绍 WS助手是WebSocket调试的开发工具&#xff0c;该客户端工具可以帮助开发人员快速连接到测试/生产环境&#xff0c;它可以帮助您监视和分析 Websocket 消息&#xff0c;并在开发过程中解决问题&#xff1b;可以模拟客户端实现与服务器的数据交互&#xff0c;并完成批量…

【DZ模板】克米设计APP手机版本地化+完美使用

模版介绍 【DZ模板】价值288克米设计APP手机版DZ模板 数据本地化完美使用 腾讯官方出品discuz论坛DIY的后台设置&#xff0c;功能齐全&#xff0c;论坛功能不亚于葫芦侠&#xff0c;自定义马甲&#xff0c;自定义认证&#xff0c;自定义广告&#xff0c;完全可以打造出自己想…

面试大杂烩之kafka

面试这个领域最近环境不行&#xff0c;所以卷起来流量挺大 关于K8s 其实看我之前的博客&#xff0c;k8s刚有点苗头的时候我就研究过&#xff0c;然后工作的时候间接接触 也自己玩过 但是用的不多就忘记了&#xff0c;正苦于不知道写什么&#xff0c;水一篇 用来面试应该是够了…

【设计模式】JAVA Design Patterns——Static Content Hosting(静态内容托管模式)

&#x1f50d;目的 将静态内容部署到基于云的存储服务&#xff0c;该服务可以将它们直接交付给客户端。 这可以减少对昂贵计算实例的需求。 &#x1f50d;解释 真实世界例子 全球性的营销网站&#xff08;静态内容&#xff09;需要快速的部署以开始吸引潜在的客户。为了将托管…