平台工具:

  • 实验平台:Linux Centos7+python3.6.8
  • 使用工具:EVE-ng、Ensp

实验拓扑:

前面的几个实验是基于同一厂商的情况下进行的。然而,实际现网运维中,数通设备产品线广阔,不同厂商直接命令略有差异。本实验通过设备分组模拟现网不同厂商设备间的差异,配合 sys.argv ,让不同组调用不同的预设脚本。实验采用eve-ng和ensp桥接linux的方式来实现的。

4、分组操作 - 图1
4、分组操作 - 图2

实验目的:

1. 192.168.11.11、192.168.11.12归类为组1,模拟思科交换机:进入 vlan 1 ,执行 description Python_G1。
2. 192.168.11.14、192.168.11.15归类为组2,模拟华为交换机:进入 vlanif 1 ,执行 description Python_G2。

准备条件:

在paramiko4.py文件同目录下,建立各组的 IP 清单列表及执行命令,如下图所示。
4、分组操作 - 图3

实验前检查

按之前实验套路,逐一检查 PC 到 LSW X的网络连通性,如不通需要排网络,本文此处描述从简。2. 检查各组每台交换机的 vlanif 是否有描述信息,实验前应如下图,如有冗余配置可手工删除掉。(做了前面几个实验的童鞋,这里的“查”“删”操作已经可以写几行代码就能实现自动化了,不妨一试。)
4、分组操作 - 图4
4、分组操作 - 图5
4、分组操作 - 图6
4、分组操作 - 图7
更多精彩内容关注“释然IT杂谈”

Python 代码

代码讲解,大神在书里和专栏中已逐条做了解释

  1. import paramiko
  2. import time
  3. import getpass
  4. import sys
  5. username = input("Username: ")
  6. password = getpass.getpass("Password: ")
  7. ip_file = sys.argv[1]
  8. cmd_file = sys.argv[2]
  9. iplist = open(ip_file,'r')
  10. for line in iplist.readlines():
  11. ip = line.strip()
  12. ssh_client = paramiko.SSHClient()
  13. ssh_client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
  14. ssh_client.connect(hostname=ip,username=username,
  15. password=password,look_for_keys=False)
  16. print('=-=-=-=-=-=-=-=-=-=-=-=-=-=')
  17. print('已经成功登陆交换机 ' + ip)
  18. command = ssh_client.invoke_shell()
  19. cmdlist = open(cmd_file,'r')
  20. cmdlist.seek(0)
  21. for line in cmdlist.readlines():
  22. each_command = line.strip()
  23. command.send(each_command + '\n')
  24. time.sleep(0.5)
  25. cmdlist.close()
  26. output = command.recv(65535).decode('ASCII')
  27. print(output)
  28. ssh_client.close()

4、分组操作 - 图8
执行脚本文件:

4、分组操作 - 图9
4、分组操作 - 图10

实验结果检测
查看各设备vlan1下描述信息。
4、分组操作 - 图11
4、分组操作 - 图12
4、分组操作 - 图13
4、分组操作 - 图14

实验小结

好了,实验完成。大家不烦动手试试看,光看很难学会,必须自己操作一番才变成自己的东西。加油! 接下来又有新问题了,这种实验 4 台被操作的交换机都是正常的(链路没断,设备正常运行),然而,现网几十、几百、上千台设备在运行,就不会有哪台设备因为传输断链,设备宕机等原因造成不通吗?如果遇到这种,咱们程序的表现如何?我们应该怎样应对呢?