Python网络自动化运维—批量登录设备
文章目录
目录
文章目录
前言
实验准备
一.批量登录 IP 连续的设备
1.1.1 实验代码
1.1.2 代码分段分解
1.1.3 实验结果验证
二.批量登录 IP 不连续的设备
2.2.1 实验代码
2.2.2 代码分段分解
2.2.3 实验结果验证
前言
在生产环境中,我们通常需要登录多个设备进行配置,设备的管理IP少数情况是同一网段的连续IP,然而在多数情况下,设备的管理IP是不连续的,在这种情况下,我们就不能简单的使用for循环来登录设备,我们要额外建立一个文本文件,把需要登录的交换机的管理IP地址全部写进去,然后用for循环配合open()函数来读取该文档中的管理IP地址,从而达到批量登录设备的目的。
实验准备
环境要求:
一.批量登录 IP 连续的设备
1.1.1 实验代码
import paramiko
import time
import getpass
def SSH_Server(ip, username, password):
ssh_client = paramiko.SSHClient()
ssh_client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh_client.connect(hostname=ip, username=username, password=password)
print(f"Successfully connected to {ip}")
last_octet = int(ip.split(".")[-1])
loopback_ip = f"{last_octet}.{last_octet}.{last_octet}.{last_octet}"
commend = ssh_client.invoke_shell()
commend.send("sys\n")
commend.send(f"int loop 1\n")
commend.send(f"ip address {loopback_ip} 255.255.255.255\n")
commend.send("return\n")
commend.send("save\n")
commend.send("Y\n")
time.sleep(2)
output = commend.recv(65535)
print(output.decode("ascii"))
ssh_client.close()
username = input("请输入用户名:")
password = getpass.getpass("请输入密码:")
for IP in [12, 13, 14]:
ip = f"192.168.223.{IP}"
SSH_Server(ip, username, password)
1.1.2 代码分段分解
关于SSH连接的paramiko模块的有关代码此处不再赘述与前文几乎一致,下面重点讲述使用for循环批量登录设备(SW2~SW4)。
for IP in [12, 13, 14]:
ip = f"192.168.223.{IP}"
SSH_Server(ip, username, password)
for
循环遍历列表 [12, 13, 14]
,每次循环生成一个新的 IP 地址 192.168.223.{IP}
。SSH_Server
函数,使用生成的 IP 地址、用户输入的用户名和密码连接到远程服务器,并执行相应的配置命令1.1.3 实验结果验证
二.批量登录 IP 不连续的设备
实验准备:
在本地电脑创建一个名为ip_list的txt文件,写入交换机的IP地址,注意该文件需要和python代码文件处于同一目录下。
2.2.1 实验代码
import paramiko
import time
import getpass
def SSH_Server(ip, username, password):
ssh_client = paramiko.SSHClient()
ssh_client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh_client.connect(hostname=ip, username=username, password=password)
print(f"Successfully connected to {ip}")
commend = ssh_client.invoke_shell()
commend.send("sys\n")
commend.send("undo stp enable\n")
commend.send("Y\n")
time.sleep(2)
output = commend.recv(65535)
print(output.decode("ascii"))
ssh_client.close()
username = input("请输入用户名:")
password = getpass.getpass("请输入密码:")
with open("ip_list","rt") as file:
for ip in file.readlines():
SSH_Server(ip.strip(),username,password)
2.2.2 代码分段分解
上述代码稍作修改,由原先的创建换回口改为关闭交换机默认开启的stp服务,下面重点讲解如何使用open()函数读取IP从而实现批量登录IP不同的交换机(SW2和SW5)。
with open("ip_list", "rt") as file:
open("ip_list", "rt")
:使用 open
函数打开名为 ip_list
的文件。其中,第一个参数 "ip_list"
是要打开的文件名;第二个参数 "rt"
表示以文本模式(t
)进行只读操作(r
)。文本模式是默认模式,所以也可以简写为 "r"
。with...as
语句:这是 Python 中的上下文管理器,它会自动处理文件的打开和关闭操作。当代码块执行完毕或发生异常时,会自动关闭文件,避免手动调用 file.close()
可能出现的资源泄漏问题。file
是文件对象,后续可以通过该对象对文件进行读取等操作。for ip in file.readlines():
file.readlines()
:调用文件对象的 readlines
方法,该方法会读取文件中的所有行,并将每一行作为一个元素存储在列表中返回。列表中的每个元素是一个字符串,且行末的换行符 \n
会被保留。for ip in...
:使用 for
循环遍历 file.readlines()
返回的列表。每次循环,变量 ip
会依次指向列表中的每个元素,即文件中的每一行(包含换行符)。SSH_Server(ip.strip(), username, password)
ip.strip()
:调用字符串对象的 strip
方法,该方法会移除字符串首尾的空白字符(包括空格、制表符、换行符等),返回一个新的字符串。因为 readlines
方法返回的每行字符串可能包含换行符,使用 strip
方法可以确保传递给 SSH_Server
函数的 IP 地址是纯净的,不包含多余的空白字符。SSH_Server(ip.strip(), username, password)
:调用之前定义的 SSH_Server
函数(在你之前提供的代码中有定义),将处理后的 IP 地址、用户名和密码作为参数传递给该函数,尝试通过 SSH 连接到对应的服务器并执行相应的配置操作。2.2.3 实验结果验证
总结
作者:北 染 星 辰