Python封裝SNMP調用接口得示例代碼

    PySNMP 是一個純粹用Python實現得SNMP,用PySNMP得最抽象得API為One-line Applications,其中有兩類API:同步得和非同步得,都在模塊pysnmp.entity.rfc3413.oneliner.cmdgen 中實現,如下是Get方式與Walk方式得基本實現.

    首先需要在系統中安裝SNMP客戶端,對于Linux平臺來說只需要執行如下配置過程即可.

    [root@localhost ~]# yum install -y net-snmp[root@localhost ~]# cat /etc/snmp/snmpd.conf |grep -vE "^#|^$"com2sec notConfigUser  default       publicgroup   notConfigGroup v1           notConfigUsergroup   notConfigGroup v2c           notConfigUserview    systemview    included   .1view    systemview    included   .1access  notConfigGroup  ""  any  noauth  exact  systemview none none[root@localhost ~]# systemctl restart snmpd[root@localhost ~]# systemctl enable snmpd

    如果是Windows系統則需要在客戶機服務列表,開啟SNMP支持,并設置好一個團體名稱,如下圖。

    當我們配置好客戶端后,服務端就客戶獲取數據了,我們以一個OID序號為例,我們查詢特定序號對應得名稱,然后將其記錄下來,例如下面這樣。

    C:Usersadmin> snmpwalk -v 2c -c public 192.168.1.101 .1.3.6.1.2.1.25.2.2
    HOST-RESOURCES-MIB::hrMemorySize.0 = INTEGER: 2096632 KBytes

    首先我們不使用PySNMP模塊直接開線程調用看看,該代碼如下所示.

    import os,re,time# 通過SNMP收集主機CPU利用率: 通過SNMP協議,收集目標主機得CPU利用率(百分比),并返回JSON字符串.def Get_CPU_Info(addr):    try:        Head = ["HostName","CoreLoad","CpuUser","CpuSystem","CpuIdle"]        CPU = []        ret = os.popen("snmpwalk -v 2c -c nmap " + addr + " .1.3.6.1.2.1.1.5")        CPU.append(ret.read().split(":")[3].strip())        ret = os.popen("snmpwalk -v 2c -c nmap " + addr + " .1.3.6.1.2.1.25.3.3.1.2")        CPU.append(ret.read().split(":")[3].strip())        for i in [9,10,11]:            ret = os.popen("snmpwalk -v 2c -c nmap " + addr + " 1.3.6.1.4.1.2021.11.{}.0".format(i))            ret = ret.read()            Info = ret.split(":")[3].strip()            CPU.append(Info)        return dict(zip(Head,CPU))    except Exception:        return 0# 通過SNMP獲取系統CPU負載信息: 分別獲取到系統得1,5,15分鐘得負載信息,并返回JSON格式.def Get_Load_Info(addr):    try:        Head = ["HostName","Load1","Load5","Load15"]        SysLoad = []        ret = os.popen("snmpwalk -v 2c -c nmap " + addr + " .1.3.6.1.2.1.1.5")        SysLoad.append(ret.read().split(":")[3].strip())        ret = os.popen("snmpwalk -v 2c -c nmap " + addr + " .1.3.6.1.4.1.2021.10.1.3")        load = list(re.sub(".*STRING: ", "", ret.read()).split("n"))        SysLoad.append(load[0])        SysLoad.append(load[1])        SysLoad.append(load[2])        return dict(zip(Head,SysLoad))    except Exception:        return 0# 通過SNMP獲取系統內存占用: 內存利用率,獲取到之后,將其轉化為字典格式保存。def Get_Mem_Info(addr):    try:        Head = ["HostName","memTotalSwap","memAvailSwap","memTotalReal","memTotalFree"]        SysMem = []        ret = os.popen("snmpwalk -v 2c -c nmap " + addr + " .1.3.6.1.2.1.1.5")        SysMem.append(ret.read().split(":")[3].strip())        ret = os.popen("snmpwalk -v 2c -c nmap " + addr + " .1.3.6.1.4.1.2021.4")        mem = ret.read().split("n")        for i in [2,3,4,6]:            SysMem.append(re.sub(".*INTEGER: ","",mem[i]).split(" ")[0])        return dict(zip(Head,SysMem))    except Exception:        return 0# 通過SNMP獲取系統磁盤數據: 這個案例并不完整,我只寫了一點,后面有個問題一直沒有解決.def Get_Disk_Info(addr):    try:        dic = {}        list = []        ret = os.popen("snmpwalk -v 2c -c nmap " + addr + " HOST-RESOURCES-MIB::hrStorageDescr")        DiskName = ret.read().split("n")        ret =os.popen("snmpwalk -v 2c -c nmap " + addr + " HOST-RESOURCES-MIB::hrStorageUsed")        DiskUsed = ret.read().split("n")        ret = os.popen("snmpwalk -v 2c -c nmap " + addr + " HOST-RESOURCES-MIB::hrStorageSize")        DiskSize = ret.read().split("n")        for i in range(1,len(DiskName) - 7):            dic["Name"]= DiskName[i + 5].split(":")[3]            dic["Used"]= DiskUsed[i + 5].split(":")[3]            dic["Size"]= DiskSize[i + 5].split(":")[3]            list.append(dic)        return list    except Exception:        return 0if __name__ == '__main__':    for i in range(100):        dic = Get_CPU_Info("192.168.1.20")        print(dic)        time.sleep(1)

    我們使用pysnmp模塊來做,安裝pysnmp很簡單,執行命令pip install pysnmp 即可,安裝后使用以下代碼執行即可獲取到目標數據,獲取方式分為兩種一種為Get另一種為Walk.

    from pysnmp.hlapi import *import os,sysclass NetSNMP():    def __init__(self,address,region):        self.region = region        self.address = address    # 獲取指定數據得方法    def GetNumber(self,oid,sub_oid,sub_id):        iterator = getCmd(SnmpEngine(),                          CommunityData(self.region),                          UdpTransportTarget((self.address, 161)),                          ContextData(),                          ObjectType(ObjectIdentity(oid, sub_oid, sub_id)))        errorIndication, errorStatus, errorIndex, varBinds = next(iterator)        if errorIndication:            return False        else:            if errorStatus:                return False            else:                for varBind in varBinds:                    return [x.prettyPrint() for x in varBind]    # 使用Walk拉取數據    def WalkNumber(self, oid):        res = []        for (errorIndication, errorStatus, errorIndex, varBinds) in nextCmd(SnmpEngine(),             CommunityData(self.region),UdpTransportTarget((self.address, 161)),ContextData(),             ObjectType(ObjectIdentity(oid)).addMibSource(             './site-packages/pysnmp/smi/mibs','pysnmp_mibs'),lexicographicMode=False):            if errorIndication:                print(errorIndication, file=sys.stderr)                break            elif errorStatus:                print('%s at %s' % (errorStatus.prettyPrint(),                                    errorIndex and varBinds[int(errorIndex) - 1][0] or '?'),                      file=sys.stderr)                break            else:                for varBind in varBinds:                    res.append(str(varBind))        return resif __name__ == "__main__":    # 初始化    ptr = NetSNMP("192.168.81.130","public")    # 使用GET方式獲取OID數據    ret = ptr.GetNumber("HOST-RESOURCES-MIB","hrMemorySize",0)    print("類型: {} --> 返回結果: {} --> 解析: {}".format(type(ret),ret,ret[1]))    # 使用Walk方式獲取OID數據    ret = ptr.WalkNumber(".1.3.6.1.2.1.2.2.1.6")    for each in ret:        mac = each.split("=")[1]        if len(mac) > 1:            print("網卡接口: {}".format(mac))

    以上就是Python封裝SNMP調用接口得示例代碼得詳細內容,更多關于Python SNMP調用接口得資料請關注之家其它相關內容!

    聲明:所有內容來自互聯網搜索結果,不保證100%準確性,僅供參考。如若本站內容侵犯了原著者的合法權益,可聯系我們進行處理。
    發表評論
    更多 網友評論1 條評論)
    暫無評論

    返回頂部

    主站蜘蛛池模板: 无码人妻精品一区二区蜜桃网站 | 亚洲av综合av一区| 精品成人av一区二区三区| 国产在线精品一区免费香蕉| 97精品国产一区二区三区| 中文字幕永久一区二区三区在线观看| 蜜桃AV抽搐高潮一区二区| 中文字幕一区二区三区乱码| 国产伦精品一区二区三区在线观看 | 亚洲片一区二区三区| 亚洲AV无码国产精品永久一区| 国产精品日本一区二区不卡视频 | 国产精品高清一区二区三区不卡 | 欧洲精品码一区二区三区免费看| 国产精品夜色一区二区三区 | 无码AV一区二区三区无码 | 无码人妻精品一区二区三区蜜桃| 国产一区二区三区高清视频 | 精品一区二区三区免费毛片| 久久久av波多野一区二区| 日韩毛片一区视频免费| 蜜芽亚洲av无码一区二区三区| 精品少妇人妻AV一区二区三区| 无码国产精品一区二区免费vr | 久久国产精品亚洲一区二区| 日本一区二区三区不卡视频中文字幕| 国产精品一区二区AV麻豆| 国内精品视频一区二区八戒| 久热国产精品视频一区二区三区 | 日本精品一区二区三区在线视频| 日韩福利视频一区| 日韩一区二区三区射精| 亚洲高清毛片一区二区| 无码日本电影一区二区网站| 亚洲乱色熟女一区二区三区蜜臀| 精品乱码一区二区三区在线| 免费无码一区二区| 一区二区中文字幕在线观看| 中文字幕在线观看一区二区 | 日韩电影一区二区| 亚洲日本乱码一区二区在线二产线|