0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

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

jf_yLA7iRus 来源:网络技术干货圈 2023-02-23 09:22 次阅读

目的:

每天自动接收附件为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。

importpexpect
importsys
importdatetime
importos
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("dislldpneighbor-informationlist")
child.expect("%s"%name)
child.sendline("dismac-address")
foriinrange(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()
$SqlCmd.commandtext = 'TRUNCATE TABLE [MAC].[dbo].[DHCPF51F]' #数据库表要提前建立好
$SqlCmd.ExecuteScalar()

#插入最新的DHCPLease记录
foreach($x in $DhcpLeaseResult1)
{
Write-Host $x.IPAddress.IPAddressToString,$x.ClientId,$x.HostName
$SqlCmd.commandtext = "INSERT INTO [MAC].[dbo].[DHCPF51F] (IP,MAC,Hostname) VALUES('{0}','{1}','{2}')" -f $x.IPAddress.IPAddressToString,$x.ClientId,$x.HostName
$SqlCmd.ExecuteScalar()
}
#
#关闭数据库连接
$SqlConn.close()

Exit

代码块3:

把txt文档截取需要的信息,输出到数据库。

importos
importsys
importpymssql
importdatetime
#数据库信息
host='x.x.x.x'
user='sa'
pwd='x.x.x.x'
db='MAC'
#登录数据库,并清空[MACF51F]表的内容
conn=pymssql.connect(host=host,user=user,password=pwd,database=db,timeout=1,login_timeout=1,charset="utf8")
cur=conn.cursor()
sqls="deletefrom[dbo].[MACF51F]"#数据库表要提前建好
cur.execute(sqls)
conn.commit()
conn.close()
today=datetime.date.today().strftime('%Y%m%d')
path="/root/F5/"+today
list1=os.listdir(path)#读取文件夹下所有txt文件,注意不要放其它文档,否则需要写判定语句。
defgetid(linea,lineb):
conn=pymssql.connect(host=host,user=user,password=pwd,database=db,timeout=1,login_timeout=1,charset="utf8")
cur=conn.cursor()
sqls1="insertinto[MACF51F]values('%s','%s','%s')"%(linea,lineb,name)#sql语句插入数据,并命名列
print(sqls)
cur.execute(sqls1)
conn.commit()
conn.close()

fortxtinlist1:
file=open('%s/%s'%(path,txt),'r+')#打开文件夹下的所有文档
name=txt[:-4]
print(txt)
print(name)


forlineinfile.readlines():

if'Learned'inline:
if'More'inline:#截取MAC地址,由于dhcp拉出来的MAC格式为xx-xx-xx-xx-xx-xx,所以我门要把交换机MACXXXX-xxxx-xxxx格式改为统一的
#linea=(line[43:57]).rstrip()
linea=(line[43:45]+'-'+line[45:48]+line[48:50]+'-'+line[50:53]+line[53:55]+'-'+line[55:57]).rstrip()
lineb=(line[84:107]).rstrip()
else:
#linea=(line[0:15]).rstrip()
linea=(line[0:2]+'-'+line[2:5]+line[5:7]+'-'+line[7:10]+line[10:12]+'-'+line[12:14]).rstrip()
lineb=(line[41:65]).rstrip()
print(linea)
print(lineb)
getid(linea,lineb)



代码块4:

抓取两个表中MAC地址一样的信息,并串接成一个表,并做成excel。

importpymssql
importxlwt
importdatetime

workbook=xlwt.Workbook()
today=datetime.date.today().strftime('%Y%m%d')
sheet1=workbook.add_sheet('sheet1',cell_overwrite_ok=True)#定义sheet1
sheet1.write(0,0,'HotName')#设置列头的名字0,0代表0行0列
sheet1.write(0,1,'MACAddress')
sheet1.write(0,2,'IPAddress')
sheet1.write(0,3,'Port')
sheet1.write(0,4,'SwitchName')


defexceladd(HotName,MACAddress,IPAddress,Port,SwitchName,index):
sheet1.write(index,0,HotName)
sheet1.write(index,1,MACAddress)
sheet1.write(index,2,IPAddress)
sheet1.write(index,3,Port)
sheet1.write(index,4,SwitchName)

host='x.x.x.x'
user='sa'
pwd='x'
db='MAC'
conn=pymssql.connect(host=host,user=user,password=pwd,database=db,timeout=1,login_timeout=1,charset="utf8")
cur=conn.cursor()
sqls="selectHostname,mac,ip,port,Switchnamefrom[dbo].[MACF51F]join[dbo].[DHCPF51F]onMAC=MACADDwherePort<>'GigabitEthernet1/0/24'orderbySwitchname,Port"#SQL命令24口是上联口排除
cur.execute(sqls)

listall=cur.fetchall()#抓取sql输出的每一行信息,并分解保存到excel表中。
index=1
forlineinlistall:
exceladd(line[0],line[1],line[2],line[3],line[4],index)
index+=1
conn.commit()
conn.close()

print('创建excel文件完成!')
workbook.save('/root/F5/%sF51FMAC.xls'%today)#保存excel

代码块5:

发送邮件代码

#coding:utf-8
fromemail.mime.textimportMIMEText
fromemail.mime.multipartimportMIMEMultipart
importsmtplib
importdatetime
fromemailimportencoders
fromemail.mime.imageimportMIMEImage
fromemail.mime.baseimportMIMEBase

today=datetime.date.today().strftime('%Y%m%d')
defsendmail():

#创建一个带附件的实例
msg=MIMEMultipart()
ctype='application/octet-stream'
maintype,subtype=ctype.split('/',1)
file=MIMEBase(maintype,subtype)
file.set_payload(open(r'/root/F5/%sF51FMAC.xls'%today,'rb').read())
file.add_header('Content-Disposition','attachment',filename='%sF51FMAC.xls'%today)
encoders.encode_base64(file)
msg.attach(file)
#加邮件头
msg_to=['xxx@xxx.com','xx@xxx.com','Klaus.Wang@xx.com','Eric.lai@xx.com']
msg['from']='xxx@xx.com'
msg['subject']=u"[接入巡检]%s"%today
msg.attach(MIMEText('接入MAC地址记录如附件','plain','utf-8'))

msg['to']=','.join(msg_to)#群发需要增加的,隐藏收件人不需要此行,直接调用msg_to就可以
server=smtplib.SMTP()
server.connect('10.17.37.96',25)#SMTP服务器地址
#server.connect('xx.quantacn.com',25)#需要认证的邮件服务器
#server.login('xx@xx.com','xxxxxxx')#XXX为用户名,XXXXX为密码
#server.sendmail(msg['from'],msg['to'],msg.as_string())单独一个收件人
server.sendmail(msg['from'],msg['to'].split(','),msg.as_string())#收件人为多个
#server.sendmail(msg['from'],msg_to,msg.as_string())
server.quit()
return'发送成功'

print(sendmail())
定期的任务计划:

1、Powershell通过windwos服务器的任务计划每天自动更新DHCP的信息

2、linux服务器通过crontab命令 定制python代码的任务计划

成果:

fc2f36bc-b316-11ed-bfe3-dac502259ad0.png

fc502dcc-b316-11ed-bfe3-dac502259ad0.png  总结:

后期会实现异常端口自动shutdown,和异常客户端DHCP拉黑MAC地址。

审核编辑 :李倩


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • MAC地址
    +关注

    关注

    1

    文章

    43

    浏览量

    11670
  • 网络设备
    +关注

    关注

    0

    文章

    266

    浏览量

    29353
  • python
    +关注

    关注

    51

    文章

    4677

    浏览量

    83473

原文标题:【实用】如何使用Python对网络设备进行运维?

文章出处:【微信号:释然IT杂谈,微信公众号:释然IT杂谈】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    外网访问家里的网络设备

    网络设备
    学习电子知识
    发布于 :2023年07月17日 20:06:18

    网络设备选择技巧

    1.硬件要兼容  在网络设备选择上,尽量使所有网络设备都采用一家公司的产品,这样可以最大限度地减少高端与低端甚至是同等级别不同设备间的不兼容问题。而且不要为了省几十块钱而选择没有质量保证的网络
    发表于 04-08 09:34

    各类网络设备

    ` 网络设备,锐捷,艾泰,D-link,华为,H3C,思科,韩电,安普`
    发表于 11-29 11:15

    Linux常用网络设备

    网络设备是计算机体系结构中必不可少的一部分,处理器如果想与外界通信,通常都会选择网络设备作为通信接口。众所周知,在 OSI(Open Systems Interconnection,开放网际互连)中,网络被划分为七个层次,从下到
    发表于 07-25 07:37

    linux的网络设备驱动之alloc_etherdev

    linux网络设备驱动之alloc_etherdev
    发表于 06-19 11:22

    如何解决高速网络设备中电线太多的问题?

    如何解决高速网络设备中电线太多的问题?
    发表于 05-18 06:57

    电脑和网络设备上常用的接口有哪些?

    电脑和网络设备上常用的接口有哪些?
    发表于 02-22 07:45

    网络设备监管系统的设计与实现

    网络设备监管是指对IP 网络中的关键设备进行实时监控和管理,使网络管理员对网络设备的使用情况有更
    发表于 06-23 13:33 24次下载

    家用网络设备简介

    家用网络设备简介 就在几年前,家用网络设备还相当简单。使用一根直连电缆、一部网络集线器或以太网路由器,您可以将两部或多部计算机连接在一起,共享外设、
    发表于 08-05 10:26 1000次阅读

    网络设备选择技巧

      1.硬件要兼容   在网络设备选择上,尽量使所有网络设备都采用一家公司的产品,这样可以最大限度地减少高端与低端甚至是同等级别不同设备间的不兼容问题。而
    发表于 12-27 10:57 1298次阅读

    解决高速网络设备中电线太多的问题

    解决高速网络设备中电线太多的问题
    发表于 11-02 08:15 0次下载
    解决高速<b class='flag-5'>网络设备</b>中电线太多的问题

    Python写SecureCRT批量登录/巡检网络设备脚本

    因为有约200台的网络设备需要每天登录巡检、查看配置、保存配置、定期更改密码(每周改一次),如果都手动去登录、配置将是非常耗费时间和人力的,所以就有了整理出脚本的想法。查看了网上大多是VBS编写的脚本,我对VBS不熟悉,刚好前段时间初步学习了Python,就想用
    的头像 发表于 12-28 09:32 3145次阅读

    使用Python网络设备进行运维的思路分析

    python代码抓取交换机的上面的信息,例如客户端的MAC地址,交换机端口,并把抓取的信息筛选,存入sqlserver数据库。
    发表于 01-26 16:38 281次阅读

    如何使用Python通过SNMP监控网络设备

    丰富的第三方库,实现绘图入库等,该方式比较繁琐,我们管理的设备还有一些网络设备,这些设备无法通过开发程序来实现监控,为了实现全平台全设备监控,我决定使用SNMP实现监控任务。
    的头像 发表于 01-09 10:38 922次阅读

    如何选择适合企业的网络设备

    进行网络设备选购前,需要对企业的网络环境进行全面的了解和分析,包括网络规模、网络拓扑结构、
    发表于 03-29 09:35 1020次阅读