运维少年系列 - python and cisco(2)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了运维少年系列 - python and cisco(2),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2886字,纯文字阅读大概需要5分钟。
内容图文
![运维少年系列 - python and cisco(2)](/upload/InfoBanner/zyjiaocheng/600/1b3617d6135e4859b22bfe4a3059e48b.jpg)
运维少年系列 - python and cisco(2)
骚年 运维少年
运维少年系列 - python and cisco(2)
一、任务概述
假设网络有多台可管理的二层交换机,现在需要在每台交换机上创建10个VLAN,在没有CDP的情况下,如何使用python完成?(别忘了python几乎适用于所有支持远程登录的设备)
二、实现步骤说明
1) 先决条件
首先准备的还是和上篇文章一样,交换机需要开启SSH和配置IP,请将所有设备登录的用户名和密码配置一致。
2) 拓扑图
3) 如何实现多IP
如果网络中有台设备,那么每台设备的IP地址都是不一样的(这是废话),我们如何去逐个登录多台设备然后执行命令呢?
在python中,如果是连续的地址,那么我们可以使用for循环实现逐个登录设备的功能,比如
[root@yunwei cisco]# cat for.py
for i in range(1,10):
print '192.168.108.%s' %i
[root@yunwei cisco]#
[root@yunwei cisco]# python for.py
192.168.108.1
192.168.108.2
192.168.108.3
192.168.108.4
192.168.108.5
192.168.108.6
192.168.108.7
192.168.108.8
192.168.108.9
但是,如果IP不是连续的怎么办呢?那么在python中我们可以将所有的IP写入一个文件,然后使用for循环去逐行循环该文件,实现登录。如
[root@yunwei cisco]# cat IP.txt
192.168.108.252
192.168.108.253
[root@yunwei cisco]#
[root@yunwei cisco]# cat for.py
ip = file('IP.txt','rb') # 以只读的形式打开文件
for i in ip.xreadlines(): # 逐行读取文件中的内容
print i,
[root@yunwei cisco]#
[root@yunwei cisco]# python for.py
192.168.108.252
192.168.108.253
[root@yunwei cisco]#
4) 如何实现多命令
如何一次性执行多个文件?我们可以像上次那样使用多次send函数,但很显然,这样效率太低了。我们可以将命令写道一个文件中,使用for循环对文件进行逐行读取,然后执行。如
[root@yunwei cisco]# cat command.txt
conf t
vlan 10
name V10
vlan 20
name V20
vlan 30
name V30
vlan 40
name V40
vlan 50
name V50
vlan 60
name V60
vlan 70
name V70
vlan 80
name V80
vlan 90
name V90
vlan 100
name V100
exit
int e0/0
switchport trunk encapsulation dot1q
switchport mode trunk
end
show vlan
show int trunk
[root@yunwei cisco]#
[root@yunwei cisco]# cat for.py
cmd = file('command.txt','rb')
for i in cmd.xreadlines():
print i,
[root@yunwei cisco]#
最终脚本
这里做个简单的注释,详细注释请参考第一篇文章。
import paramiko # 导入模块
import time
user = 'yunwsn' # 定义登录用户名
passwd = '123456' # 定义登录密码
s = paramiko.SSHClient() # 实例化
s.set_missing_host_key_policy(paramiko.AutoAddPolicy())
IP = file('IP.txt','rb') # 打开IP文件
for ip in IP.xreadlines(): # 循环IP文件
s.connect(ip,username=user,password=passwd,look_for_keys=False,allow_agent=False) # 登录读取到的IP文件行
print '[ \033[0;32m success\033[0m ] login %s ' %ip # 打印登录成功信息
cmd = s.invoke_shell() # 交互式sshell
command = file('command.txt','rb') # 因为上面已经登录成功,这里打开命令文件
for command in command.xreadlines(): # 逐行读取命令
cmd.send(command) # 执行命令
time.sleep(0.1)
output = cmd.recv(65535) # 每执行一个命令就打印一次
print output
cmd.close() # 一个IP命令执行完毕,关闭交互式shell,循环下一个ip
IP.close() # 全部Ip执行完成,则关闭IP文件
效果如下(动图)
登录交换机查看结果
内容总结
以上是互联网集市为您收集整理的运维少年系列 - python and cisco(2)全部内容,希望文章能够帮你解决运维少年系列 - python and cisco(2)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。