from netmiko import ConnectHandler
import datetime
import threading
import concurrent.futures
import os
# 假设您的IP地址列表保存在一个名为"ips.txt"的文本文件中,每行一个IP地址
ip_file = "ips.txt" # 确保此文件存在并包含IP地址
# 从环境变量或配置文件读取敏感信息
USERNAME = os.environ.get("NETMIKO_USERNAME", "默认登录账号")
PASSWORD = os.environ.get("NETMIKO_PASSWORD", "默认登录密码")
def save_output_to_file(ip):
try:
# 获取当前时间,用于文件名
now = datetime.datetime.now().strftime("%Y%m%d%H%M%S")
# 构建文件名,格式为 IP地址_当前时间.txt
filename = f"{ip}_{now}.txt"
# 设备连接参数
device = {
'device_type': 'hp_comware', # 根据您的设备类型修改
'ip': ip,
'username': USERNAME,
'password': PASSWORD,
'global_delay_factor': 0.1, # 可选的,用于调整所有延迟的乘数
'timeout': 60, # 设置超时时间
}
# 使用 with 语句确保连接被正确关闭
with ConnectHandler(**device) as connection:
output = connection.send_command('display cur') # 确保命令与您的设备兼容
except Exception as e:
# 只写入失败的 IP 地址到 fail.txt
with open("fail.txt", 'a') as fail_file:
fail_file.write(f"{ip}\n")
print(f"Error connecting to or executing command on {ip}: {e}")
# 读取IP地址列表
with open(ip_file, 'r') as file:
ip_addresses = file.read().splitlines()
# 使用线程池限制并行线程数量
with concurrent.futures.ThreadPoolExecutor(max_workers=10) as executor:
# 为每个IP地址创建一个线程并提交到线程池
for ip in ip_addresses:
executor.submit(save_output_to_file, ip)
print("All tasks submitted to the thread pool.")
Python自动备份优化后—取消了进程ID
于 2024-02-28 10:56:59 首次发布
本文介绍如何使用Python的NetMiko库连接并控制多个网络设备,通过线程池并发执行displaycur命令,将结果保存到文件,同时处理连接失败情况。
摘要由CSDN通过智能技术生成