‘由于从事通信行业,经常有检测交换机路由器路由表变化的需要。之前比较用得多的是java,但是最近开始接触python,就想着用python来练练手。实际开发的时候发现用python写运维脚本还是挺方便的,最重要的是第三方库比较多。
这次主要用到的第三方库是pysnmp。
pysnmp依赖两个第三方的Python库:
(1) ASN.1 : Structure of Management Information:管理信息结构
(2) Cryptography Toolkit: 用来加密的
安装的过程为先安装ASN.1 和Cryptography的python库,最后安装pysnmp
其次还有一些平时可能比较少用python自带库,pickle,还有collections里的defaultdict。
我个人使用defaultdict较多,与dict类型不同,你不需要检查key是否存在。并且当你在一个字典中对一个键进行嵌套赋值时,如果这个键不存在,会触发keyError异常。 defaultdict允许我们用一个聪明的方式绕过这个问题。
import collections
def tree():
return defaultdict(int)
some_dict = tree()
some_dict['colours']['favourite'] = "yellow"
Python中可以使用 pickle 模块将对象转化为文件保存在磁盘上,在需要的时候再读取并还原。
使用pickle主要是为了方便存储读写defaultdict的数据。
下面直接撸代码。
检测到路由表变化,要把变化发送到syslog服务器上:
# -*- encoding: utf-8 -*-
"""
Python syslog client.
"""
import socket
# 设备类型
FACILITY = {
'kern': 0, 'user': 1, 'mail': 2, 'daemon': 3,
'auth': 4, 'syslog': 5, 'lpr': 6, 'news': 7,
'uucp': 8, 'cron': 9, 'authpriv': 10, 'ftp': 11,
'local0': 16, 'local1': 17, 'local2': 18, 'local3': 19,
'local4': 20, 'local5': 21, 'local6': 22, 'local7': 23,
}
# 告警等级
LEVEL = {
'emerg': 0, 'alert': 1, 'crit': 2, 'err': 3,
'warning': 4, 'notice': 5, 'info': 6, 'debug': 7
}
# 发送信息,告警等级,设备类型,syslog服务器地址、端口
def syslog(message, level=LEVEL['notice'], facility=FACILITY['daemon'], host='localhost', port=514):
try:
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
data = '<%d>%s' % (level + facility * 8, message)
sock.sendto(data, (host, port))
sock.close()
except Exception:
pass
路由表监测主要代码(注释一开始用英文写,不过英文比较烂,必要的地方我在再改中文注释):
# -*encoding:utf-8*-
import datetime
from pysnmp.entity.rfc3413.oneliner import cmdgen
from collections import defaultdict
import pickle
import threading
import time
from syslog import sendSyslog
_version = '1.0'
'''
def tree(): return defaultd