实验拓扑:
cloud连接本机,ip地址为192.168.56.1,五台交换机的配置的地址为192.168.1.11~55。现在通过paramiko,ssh进入五台设备,并且在五台设备上分别创建vlan10-vlan20这11个VLAN。
版本:python3.9
实验步骤:
一、ssh配置:
## 创建秘钥
[sw2]dsa local-key-pair create
## 配置SSH认证类型(密码/其他)
[sw2]ssh user prin authentication-type password
[sw2]ssh user prin service-type stelnet
[sw2]stelnet server enable
## 配置认证模式
[sw2]user-interface vty 0 4
[sw2-ui-vty0-4]authentication-mode aaa //配置认证模式
[sw2-ui-vty0-4]protocol inbound ssh //允许 ssh 连接虚拟终端
## 配置本地用户信息
[sw2]aaa
[sw2-aaa] local-user prin password cipher Huawei@123
[sw2-aaa]local-user prin privilege level 15
[sw2-aaa] local-user prin service-type ssh
二、python脚本:
import paramiko
import time
import getpass
#使用input函数,输入SSH的用户名
username = input('Username: ')
#通过getpass()函数接收密码,密码是不可见的,但是在windows上有bug,密码可见
password = getpass.getpass('Password: ')
#创建一个列表,表示五台设备最后8位的地址
ip_tail_list = [11, 22, 33, 44, 55]
#使用for循环,接受SSH的秘钥,并分别依次连接到五台设备,注意需要将i转化为字符串
for i in ip_tail_list:
ip = "192.168.56." + str(i)
ssh_client = paramiko.SSHClient()
ssh_client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh_client.connect(hostname=ip, username=username, password=password)
print("Successfully connect to ", ip)
#使用invoke_shell()唤醒shell界面
command = ssh_client.invoke_shell()
#使用command.send()函数创建VLAN,并且设置每个VLAN的描述;未来保证设备能够正常接受配置,每次创建1个VLAN后休息1s
command.send("system \n")
for n in range(10, 21):
print("Creating Vlan " + str(n))
command.send("vlan " + str(n) + "\n")
command.send("description Python Vlan" + str(n) + "\n")
time.sleep(1)
#保存配置,并且通过command.recv()函数得到回信的信息,最多接受65535个字符
command.send("return \n")
command.send("save \n"+"y \n"+"\n")
time.sleep(2)
output = command.recv(65535)
print(output.decode('ascii'))
#关闭连接
ssh_client.close()
如果管理的设备数目过多,可以直接通过读取txt文件的方式获取IP地址,仅需要将如下代码:
#创建一个列表,表示五台设备最后8位的地址
ip_tail_list = [11, 22, 33, 44, 55]
#使用for循环,接受SSH的秘钥,并分别依次连接到五台设备,注意需要将i转化为字符串
for i in ip_tail_list:
ip = "192.168.56." + str(i)
ssh_client = paramiko.SSHClient()
ssh_client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh_client.connect(hostname=ip, username=username, password=password)
#......省略中间部分
ssh_client.close()
更换为下述即可:
#使用open()函数打开ip_list文件,并将读取的结果赋予f
f = open("ip_list.txt","r")
#调用readlines()函数,返回IP地址的列表,并使用for循环遍历;注意使用readlines()的每一个ip地址后带有\n,需要通过strip()函数去除
for i in f.readlines():
ip = i.strip()
ssh_client = paramiko.SSHClient()
ssh_client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh_client.connect(hostname=ip, username=username, password=password)
#.......省略中间部分,在完成文件操作后,关闭文件
f.close()
ssh_client.close()
执行效果:
…在设备上检查是否配置成功,以SW1为例:
可以看到创建VLAN和添加VLAN描述成功。