【实用】如何使用Python对网络设备进行运维?

目的:

每天自动接收附件为excel表格的邮件,里面包含客户端IP地址、客户端MAC地址、客户端计算机名、交换机端口、交换机的名字等信息。可以给运维人员带来一些方便,直观的查看那些非法的设备接入交换机的那个端口,方便远程shutdown端口(自动shutdown端口和DHCP拉黑MAC地址,还在编写中)。

思路:

1、用python代码抓取交换机的上面的信息,例如客户端的MAC地址,交换机端口,并把抓取的信息筛选,存入sqlserver数据库。
2、用Powershell抓去DHCP的信息,筛选客户端的MAC地址,计算机名信息存入sqlserver数据库。
3、通过Python代码,调用SQL语句,把输出结果保存到excel表格。 4、通过Python代码,发送邮件。
5、linux通过crontab,Powershell通过自动任务计划,每天定时执行代码和脚本。

代码块1:

抓取交换机信息代码,并保存到本地的txt。

import pexpect
import sys
import datetime
import os
today=datetime.date.today().strftime('%Y%m%d')
path = "/root/F5/"+today#创建文件夹
os.mkdir(path,777)
ip='x.x.x.x'
passwd='^^^^^'
txt='F51FA-x.x.x.x.txt'
name=''#交换机名字
name1="---- More ----"
child=pexpect.spawn('telnet %s'%ip)#telnet交换机
fout=open('/root/F5/'+today+'/'+txt,'wb+')#输出结果保存到此txt
child.logfile = fout
child.expect('Username:')
child.sendline("admin")
child.expect('(?i)ssword:')
child.sendline("%s"%passwd)
child.expect("%s"%name)
child.sendline("dis lldp neighbor-information list")
child.expect("%s"%name)
child.sendline("dis mac-address")
for i in range(10):
  index = child.expect([name1,"%s"%name])#命令输出结果如果需要空格翻页
  if ( index == 0 ):
    child.send(" ")
  else:
    child.sendline("quit")#如果还有其它命令可以写在这里
    sys.exit()

代码块2:

powershell抓取DHCP信息,并输出到数据库。

#数据库配置信息
$Database = 'MAC'
$Server = 'xx'
$UserName = 'sa'
$Password = 'xx'
#powershell 抓取DHCP 可以看网页 http://blog.51cto.com/wenzhongxiang/2065645

#读取DHCPLease记录
#$DhcpLeaseResult1 = Get-DhcpServerv4Scope -ComputerName x.x.x.x |Get-DhcpServerv4Lease -ComputerName x.x.x.x |Select-Object IPAddress,ClientId,HostName #这个命令是抓取DHCP服务器 x.x.x.x 的所有信息 只输出IPAddress,ClientId,HostName 三列
$DhcpLeaseResult1 = Get-DhcpServerv4Lease -ComputerName x -ScopeId y.y.y.y |Select-Object IPAddress,ClientId,HostName
#抓取DHCP服务器X(名字或者IP),y.y.y.y作用域的信息,只输出IPAddress,ClientId,HostName三列
#创建连接对象
$SqlConn = New-Object System.Data.SqlClient.SqlConnection

#使用账号连接MSSQL
$SqlConn.ConnectionString = "Data Source=$Server;Initial Catalog=$Database;user id=$UserName;pwd=$Password"


#打开数据库连接
$SqlConn.open()
#清空数据库里DHCPLease记录
$SqlCmd = $SqlConn.CreateCommand(</
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值