当前位置: 首页 > article >正文

基于 Netmiko 的网络设备自动化操作

在这里插入图片描述

学习目标
  1. 掌握 Netmiko 库的核心功能与使用场景。
  2. 能够通过 Netmiko 连接多厂商设备并执行命令和配置。
  3. 实现批量设备管理、配置备份与自动化巡检。
  4. 掌握异常处理、日志记录与性能优化技巧。
  5. 理解 Netmiko 在自动化运维体系中的角色。

1. Netmiko 简介

1.1 什么是 Netmiko

  • Netmiko 是一个基于 Python 的多厂商网络设备连接库,封装了 SSH/Telnet 协议,简化了与网络设备(如路由器、交换机、防火墙)的交互流程。
  • 支持 Cisco IOS、华为、Juniper、Arista 等 50+ 厂商设备(完整支持列表)。

1.2 Netmiko 的优势

  • 多厂商兼容:统一接口适配不同设备。
  • 简化交互:自动处理登录、特权模式切换、分页输出等问题。
  • 扩展性强:支持自定义设备类型与解析逻辑。

1.3 应用场景

  • 批量配置下发(如 VLAN、ACL、路由协议)。
  • 设备状态巡检与监控(CPU、内存、接口状态)。
  • 配置文件备份与恢复。
  • 自动化故障排查。

2. Netmiko 基础操作

2.1 安装与环境配置

# 安装 Netmiko
pip install netmiko# 安装依赖库(可选,用于解析结构化数据)
pip install textfsm ntc-templates

2.2 核心类与方法

  • ConnectHandler:建立设备连接的核心类。
  • send_command():发送命令并返回输出。
  • send_config_set():发送配置命令集。
  • enable():进入特权模式。
  • disconnect():关闭连接。

2.3 连接设备基础示例

from netmiko import ConnectHandler# 定义设备参数
device = {"device_type": "cisco_ios","ip": "192.168.1.1","username": "admin","password": "cisco123","secret": "enable123",  # 特权密码(可选)
}# 连接设备并执行命令
try:conn = ConnectHandler(**device)conn.enable()  # 进入特权模式output = conn.send_command("show version")print(output)conn.disconnect()
except Exception as e:print(f"连接失败: {e}")

3. 进阶功能与实践

3.1 配置管理

  • 批量配置下发

    config_commands = ["interface GigabitEthernet0/1","description 由Netmiko自动配置","ip address 10.1.1.1 255.255.255.0"
    ]
    output = conn.send_config_set(config_commands)
    print(output)
    
  • 从文件读取配置

    with open("config.txt", "r") as f:commands = f.read().splitlines()
    conn.send_config_set(commands)
    

3.2 数据解析与自动化巡检

  • 使用 TextFSM 结构化解析

    # 需要安装 ntc-templates
    output = conn.send_command("show interfaces", use_textfsm=True)
    for interface in output:if interface["link_status"] == "up":print(f"接口 {interface['interface']} 状态正常")
    
  • 生成巡检报告

    import csv
    report = []
    commands = ["show version", "show ip interface brief", "show processes cpu"]
    for cmd in commands:output = conn.send_command(cmd, use_textfsm=True)report.append({cmd: output})# 保存为 CSV 文件
    with open("inspection_report.csv", "w") as f:writer = csv.DictWriter(f, fieldnames=report[0].keys())writer.writeheader()writer.writerows(report)
    

3.3 配置文件备份

import time
backup_time = time.strftime("%Y%m%d-%H%M%S")
output = conn.send_command("show running-config")
with open(f"backup_{device['ip']}_{backup_time}.cfg", "w") as f:f.write(output)

4. 异常处理与调试

4.1 常见异常类型

  • NetMikoTimeoutException:连接超时(检查 IP/端口/网络可达性)。
  • NetMikoAuthenticationException:认证失败(检查用户名/密码)。
  • ReadTimeout:命令执行超时(调整 timeout 参数)。

4.2 调试与日志记录

import logging# 启用 Netmiko 日志
logging.basicConfig(filename="netmiko_debug.log",level=logging.DEBUG,format="%(asctime)s - %(name)s - %(levelname)s - %(message)s"
)# 重试逻辑示例
from netmiko.ssh_exception import NetMikoTimeoutExceptionretries = 3
for attempt in range(retries):try:conn = ConnectHandler(**device)breakexcept NetMikoTimeoutException:if attempt == retries - 1:raiseprint(f"第 {attempt+1} 次重试...")

5. 性能优化与批量操作

5.1 多线程处理多设备

from concurrent.futures import ThreadPoolExecutordevices = [{"device_type": "cisco_ios", "ip": "192.168.1.1", ...},{"device_type": "huawei", "ip": "192.168.1.2", ...},
]def backup_config(dev):conn = ConnectHandler(**dev)output = conn.send_command("show running-config")conn.disconnect()return outputwith ThreadPoolExecutor(max_workers=5) as executor:results = executor.map(backup_config, devices)for result in results:print(result)

5.2 连接池与长连接优化

  • 对频繁操作的设备保持长连接,避免重复认证开销。

6. 实战案例:企业级自动化运维项目

场景:某企业需每日备份全网 100+ 台设备的配置,并检查关键接口状态。

解决方案

  1. 设备清单管理:使用 YAML/JSON 文件存储设备信息。
  2. 并发备份配置:通过多线程加速。
  3. 异常告警:失败时发送邮件通知。
  4. 报告生成:汇总所有设备状态至 HTML 报告。

关键代码片段

import yaml
import smtplib
from email.mime.text import MIMEText# 读取设备清单
with open("devices.yaml", "r") as f:devices = yaml.safe_load(f)# 并发备份配置
def backup_and_check(dev):try:conn = ConnectHandler(**dev)config = conn.send_command("show running-config")interfaces = conn.send_command("show interfaces", use_textfsm=True)conn.disconnect()# 检查接口状态for intf in interfaces:if intf["link_status"] != "up":send_alert(f"设备 {dev['ip']} 接口 {intf['interface']} 异常!")return configexcept Exception as e:send_alert(f"设备 {dev['ip']} 备份失败: {e}")# 发送邮件告警
def send_alert(message):msg = MIMEText(message)msg["Subject"] = "自动化运维告警"msg["From"] = "alert@example.com"msg["To"] = "admin@example.com"smtp_server.send_message(msg)# 执行任务
with ThreadPoolExecutor(max_workers=20) as executor:executor.map(backup_and_check, devices)

7. 本章小结
  • Netmiko 是网络自动化运维的核心工具,提供跨厂商设备的统一操作接口。
  • 重点掌握连接管理、命令下发、配置备份与异常处理。
  • 结合多线程/协程技术,可显著提升大规模设备管理效率。

相关文章:

基于 Netmiko 的网络设备自动化操作

学习目标 掌握 Netmiko 库的核心功能与使用场景。能够通过 Netmiko 连接多厂商设备并执行命令和配置。实现批量设备管理、配置备份与自动化巡检。掌握异常处理、日志记录与性能优化技巧。理解 Netmiko 在自动化运维体系中的角色。 1. Netmiko 简介 1.1 什么是 Netmiko Netmi…...

玉米产量遥感估产系统的开发实践(持续迭代与更新)

项目地址:项目首页 - maize_yield_estimation:玉米估产的flaskvue项目 - GitCode 开发中,敬请期待。。。 以下是预先写的提纲,准备慢慢补充 一、项目背景与工程目标 业务需求分析 农业遥感估产的行业痛点(数据分散、模型精度不足…...

LeNet5 神经网络的参数解析和图片尺寸解析

1.LeNet-5 神经网络 以下是针对 LeNet-5 神经网络的详细参数解析和图片尺寸变化分析,和原始论文设计,通过分步计算说明各层的张量变换过程。 经典的 LeNet-5架构简化版(原始论文输入为 32x32,MNIST 常用 28x28 需调整&#xff09…...

Axure大屏可视化模板:多领域数据决策的新引擎

在数据驱动决策的时代,Axure大屏可视化模板凭借交互性与可定制性,成为农业、园区管理、智慧城市、企业及医疗领域的创新工具,助力高效数据展示与智能决策。 核心应用场景 1. 农业精细化:实时监控土壤湿度、作物生长曲线&#x…...

大内存生产环境tomcat-jvm配置实践

话不多讲,奉上代码,分享经验,交流提高! 64G物理内存,8核CPU生产环境tomcat-jvm配置如下: JAVA_OPTS-server -XX:MaxMetaspaceSize4G -XX:ReservedCodeCacheSize2G -XX:UseG1GC -Xms48G -Xmx48G -XX:MaxGCPauseMilli…...

APP和小程序需要注册域名吗?(国科云)

在移动互联网时代,APP和小程序已成为企业和个人提供服务、展示产品的重要渠道。那么APP和小程序的兴起是否对域名造成了冲击,APP和小程序是否需要注册域名呢? APP是否需要注册域名? 从技术上讲,没有域名的APP仍然可以…...

代码随想录算法训练营第60期第十七天打卡

今天我们继续进入二叉树的下一个章节,今天的内容我在写今天的博客前大致看了一下部分题目难度不算大,那我们就进入今天的题目。 第一题对应力扣编号为654的题目最大二叉树 这道题目的坑相当多,我第一次题目没有看明白就是我不知道到底是如何…...

小刚说C语言刷题——1565成绩(score)

1.题目描述 牛牛最近学习了 C 入门课程,这门课程的总成绩计算方法是: 总成绩作业成绩 20% 小测成绩 30% 期末考试成绩 50%。 牛牛想知道,这门课程自己最终能得到多少分。 输入 三个非负整数 A、B、C ,分别表示牛牛的作业成…...

SOC估算:开路电压修正的安时积分法

SOC估算:开路电压修正的安时积分法 基本概念 开路电压修正的安时积分法是一种结合了两种SOC估算方法的混合技术: 安时积分法(库仑计数法) - 通过电流积分计算SOC变化 开路电压法 - 通过电池电压与SOC的关系曲线进行校准 方法原…...

Spark-SQL(总结)

了解到Spark SQL是Spark用于结构化数据处理的模块,其前身是Shark。Shark基于Hive开发,但对Hive的依赖制约了Spark的发展。掌握了 Spark - SQL 的特点,如易整合、统一数据访问、兼容 Hive 以及支持标准数据连接,可处理多种数据源的…...

Oracle for Linux安装和配置(11)——Oracle安装和配置

11.3. Oracle安装和配置 Linux上Oracle的安装及配置与Windows上差不多,只是安装软件的准备等有所不同,下面只对不同于Windows的部分进行较为详细的讲解,其他类似部分不再赘述。另外,无论选择使用虚机还是物理机,Oracle安装、配置和使用等方面几乎都是完全一样的。 11.3.…...

【防火墙 pfsense】2配置

(1)接口配置和接口 IP 地址分配 ->配置广域网(WAN)和局域网(LAN)接口,分配设备标识符,如 eth0、eth1 等; ->如将WAN 接口将被分配到 eth0,而 LAN 接口将…...

使用 SSE + WebFlux 推送日志信息到前端

为什么使用 SSE 而不使用 WebSocket, 请看 SEE 对比 Websocket 的优缺点。 特性SSEWebSocket通信方向单向(服务器→客户端)双向(全双工)协议基于 HTTP独立协议(需 ws:// 前缀)兼容性现代浏览器&#xff08…...

Ollama 常见命令速览:本地大模型管理指南

Ollama 常见命令速览:本地大模型管理指南 一、什么是 Ollama? Ollama 是一个轻量级工具,允许用户在本地快速部署和运行大型语言模型(LLM),如 Llama、DeepSeek、CodeLlama 等。其命令行工具设计简洁&#…...

C++开发之设计模式

设计模式存在的意义 设计模式提供了经过验证的解决方案,帮助开发者在不同的项目中重用这些解决方法,减少重复劳动,提高代码的复用性。设计模式通常遵循面向对象的设计原则,如单一职责原则、开放封闭原则等,能够帮助开…...

AWS Glue ETL设计与调度最佳实践

一、引言 在AWS Glue中设计和调度ETL过程时,需结合其无服务器架构和托管服务特性,采用系统化方法和最佳实践,以提高效率、可靠性和可维护性。本文将从调度策略和设计方法两大维度详细论述,并辅以实际案例说明。 二、调度策略的最…...

二叉树的遍历(广度优先搜索)

二叉树的第二种遍历方式,层序遍历,本质是运用队列对二叉树进行搜索。 层序遍历是指将二叉树的每一层按顺序遍历,通过队列实现就是先将根节点push入队,统计此时的队列中的元素数量size,将size元素全部pop出去&#xff0…...

JavaScript 里创建对象

咱们来用有趣的方式探索一下 JavaScript 里创建对象的各种“魔法咒语”! 想象一下,你是一位魔法工匠,想要在你的代码世界里创造各种奇妙的“魔法物品”(也就是对象)。你有好几种不同的配方和工具: 1. 随手捏造(对象字面量 {}) 场景:你想快速做一个独一无二的小玩意儿…...

2025年计算机视觉与智能通信国际会议(ICCVIC 2025)

2025 International Conference on Computer Vision and Intelligent Communication 一、大会信息 会议简称:ICCVIC 2025 大会地点:中国杭州 收录检索:提交Ei Compendex,CPCI,CNKI,Google Scholar等 二、会议简介 2025年计算机视觉与智能通…...

手工收集统计信息

有时想对某些表收集统计信息 CREATE OR REPLACE PROCEDURE GATHER_STATS ASDECLAREV_SQL1 VARCHAR(1000);--表游标CURSOR C1 ISSELECT (SELECT USER) AS TABLE_OWNER,TABLE_NAMEFROM USER_TABLES; --可以在这里加过滤条件--索引游标CURSOR C2 ISSELECT TABLE_OWNER,INDEX_NAM…...

flume整合Kafka和spark-streaming核心编程

flume整合Kafka 需求1:利用flume监控某目录中新生成的文件,将监控到的变更数据发送给kafka,kafka将收到的数据打印到控制台: 1.查看topic 2.编辑flume-Kafka.conf,并启动flume 3.启动Kafka消费者 4.新增测试数据 5.查…...

tokenizer的用法

下面介绍下基于 Hugging Face Transformers 库中 tokenizer(分词器)的主要用法和常用方法,帮助你了解如何在各种场景下处理文本。这里以 AutoTokenizer 为例,但大多数模型对应的 tokenizer 用法大同小异。 ───────────…...

kotlin和MVVM的结合使用总结(二)

MVVM 架构详解 核心组件:ViewModel 和 LiveData 在 Android 中,MVVM 架构主要借助 ViewModel 和 LiveData 来实现。ViewModel 负责处理业务逻辑,而 LiveData 则用于实现数据的响应式更新。 ViewModel 的源码分析 ViewModel 的核心逻辑在 …...

Git 入门知识详解

文章目录 一、Git 是什么1、Git 简介2、Git 的诞生3、集中式 vs 分布式3.1 集中式版本控制系统3.2 分布式版本控制系统 二、GitHub 与 Git 安装1、GitHub2、Git 安装 一、Git 是什么 1、Git 简介 Git 是目前世界上最先进的分布式版本控制系统。版本控制系统能帮助我们更好地管…...

React.memo 和 useMemo

现象 React 中,通常父组件的某个state发生改变,会引起父组件的重新渲染(和其他state的重新计算),从而会导致子组件的重新渲染(和其他非相关属性的重新计算) 问题一:如何避免因为某个…...

EDI 如何与 ERP,CRM,WMS等系统集成

在数字化浪潮下,与制造供应链相关产业正加速向智能化供应链转型。传统人工处理订单、库存和物流的方式已难以满足下单客户对响应速度和数据准确性的严苛要求。EDI技术作为企业间数据交换的核心枢纽,其与ERP、CRM、WMS等业务系统的深度集成,成…...

面试踩过的坑

1、 “”和equals 的区别 “”是运算符,如果是基本数据类型,则比较存储的值;如果是引用数据类型,则比较所指向对象的地址值。equals是Object的方法,比较的是所指向的对象的地址值,一般情况下,重…...

论文阅读:2024 ACL ArtPrompt: ASCII Art-based Jailbreak Attacks against Aligned LLMs

总目录 大模型安全相关研究:https://blog.csdn.net/WhiffeYF/article/details/142132328 Artprompt: Ascii art-based jailbreak attacks against aligned llms https://www.doubao.com/chat/3846685176618754 https://arxiv.org/pdf/2402.11753 https://github…...

多物理场耦合低温等离子体装置求解器PASSKEy2

文章目录 PASSKEy2简介PASSKEY2计算流程PASSKEy2 中求解的物理方程电路模型等离子体模型燃烧模型 PASSKEy2的使用 PASSKEy2简介 PASSKEy2 是在 PASSKEy1 的基础上重新编写的等离子体数值模拟程序。 相较于 PASSKEy1, PASSKEy2 在具备解决低温等离子体模拟问题的能力…...

视频噪点多,如何去除画面噪点?

你是否遇到过这样的困扰?辛辛苦苦拍摄的视频,导出后却满屏 “雪花”,夜景变 “噪点盛宴”,低光环境秒变 “马赛克现场”? 无论是日常拍摄的vlog、珍贵的家庭录像,还是专业制作的影视作品,噪点问…...