0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

如何使用Python PySNMP模塊獲取設備指標呢?

網絡技術干貨圈 ? 來源:網絡技術干貨圈 ? 2024-01-12 13:59 ? 次閱讀

一、PySNMP模塊介紹:

PySNMP 是一個跨平臺的純Python SNMP 引擎實現。它具有功能齊全的 SNMP 引擎,能夠充當代理/管理器/代理角色,通過 IPv4/IPv6 和其他網絡傳輸傳輸 SNMP v1/v2c/v3 協(xié)議版本。目前,使用較多的是SNMP v3和v2c版本。三個版本的區(qū)別如下:

SNMPv1:SNMP的第一個版本,它提供了一種監(jiān)控和管理計算機網絡的系統(tǒng)方法,它基于團體名認證,安全性較差,且返回報文的錯誤碼也較少。它在RFC 1155和RFC 1157中定義。

SNMPv2c:第二個版本SNMPv2c引入了GetBulk和Inform操作,支持更多的標準錯誤碼信息,支持更多的數據類型。它在RFC 1901,RFC 1905和RFC 1906中定義。

SNMPv3:鑒于SNMPv2c在安全性方面沒有得到改善,IETF頒布了SNMPv3版本,提供了基于USM(User Security Module)的認證加密和基于VACM(View-based Access Control Model)的訪問控制,是迄今為止最安全的版本。SNMPv3在RFC 1905,RFC 1906,RFC 2571,RFC 2572,RFC 2574和RFC 2575中定義。

模塊官網地址:

https://pysnmp.readthedocs.io/en/latest/

二、SNMP v2c實驗

實驗目的: 通過PySNMP Version 4.4.12 SNMP v2c收集Cisco ASAv防火墻的各項指標。

實驗設備: ASAv 992,IP地址10.1.102.254。

實驗步驟:

首先對ASAv設備進行初始化配置:

interfaceGigabitEthernet0/0
nameifinside
security-level100
ipaddress10.1.102.254255.255.255.0
noshutdown

接下來配置SNMPv2,允許來自inside區(qū)域的10.1.1.1設備進行SNMP訪問,只讀community值為tcpipro。

snmp-serverenable
snmp-serverhostinside10.1.1.1communitytcpipro
snmp-servercommunitytcpipro

配置完成后,通過如下Python代碼進行測試:

frompysnmp.hlapiimport*


defsnmpv2_get(ip,community,oid,port=161):
#varBinds是列表,列表中的每個元素的類型是ObjectType(該類型的對象表示MIBvariable)
errorindication,errorstatus,errorindex,varbinds=next(
getCmd(SnmpEngine(),
CommunityData(community),#配置community
UdpTransportTarget((ip,port)),#配置目的地址和端口號
ContextData(),
ObjectType(ObjectIdentity(oid))#讀取的OID
)
)
#錯誤處理
iferrorindication:
print(errorindication)
eliferrorstatus:
print('%sat%s'%(
errorstatus,
errorindexandvarbinds[int(errorindex)-1][0]or'?'
)
)
#如果返回結果有多行,需要拼接后返回
result=""
forvarBindinvarbinds:
result=result+varBind.prettyPrint()#返回結果!
#返回的為一個元組,OID與字符串結果
returnresult.split("=")[0].strip(),result.split("=")[1].strip()


if__name__=="__main__":
ASA_oid={"CPUTotal1min":"1.3.6.1.4.1.9.9.109.1.1.1.1.7.1","MemoryUsed":"1.3.6.1.4.1.9.9.48.1.1.1.5.1",
"MemoryFree":"1.3.6.1.4.1.9.9.48.1.1.1.6.1","ifInOctets-G0-Outside":"1.3.6.1.2.1.2.2.1.10.3",
"ifOutOctets-G0-Outside":"1.3.6.1.2.1.2.2.1.16.3","ifInOctets-G1-Inside":"1.3.6.1.2.1.2.2.1.10.4",
"ifOutOctets-G1-Inside":"1.3.6.1.2.1.2.2.1.16.4","TotalIPSec":"1.3.6.1.4.1.9.9.392.1.3.26.0",
"L2LIPSec":"1.3.6.1.4.1.9.9.392.1.3.29.0","AnyConnectVPN":"1.3.6.1.4.1.9.9.392.1.3.35.0",
"WebVPN":"1.3.6.1.4.1.9.9.392.1.3.38.0"}

forkey,valueinASA_oid.items():
try:
print(key+':',snmpv2_get("10.1.102.254","tcpipro",value))
exceptExceptionase:
print(e)

Tips:要獲取特定 ASA 的受支持 SNMP MIB 和 OID 的列表,請輸入以下命令:show snmp-server oidlist進行查看?;蛘?,我們可以通過一些SNMP測試軟件進行查詢,例如ByteSphere OidView。最終python測試結果如圖1所示:

cfa6d234-b10e-11ee-8b88-92fbcf53809c.png

圖1 SNMP v2c測試結果

三、SNMP v3實驗

實驗目的: 通過PySNMP的SNMP v3收集Cisco ASAv防火墻的各項指標。

實驗設備: ASAv 992,IP地址10.1.102.254。

實驗步驟:

完成ASA接口初始化配置后,進行SNMP v3的配置,如下所示:

snmp-serverenable
snmp-servergroupsnmpgroupv3priv
snmp-serveruseradminsnmpgroupv3authshaCisc0123privaes256Cisc0123
snmp-serverhostinside10.1.1.1version3admin

SNMP v3配置中需要注意的是,首先我們創(chuàng)建了一個SNMP v3認證group snmpgroup,在這個group的用戶數據需要同時進行身份驗證和加密(priv)。其中,auth 關鍵字可啟用數據包身份驗證。noauth 關鍵字表示未在使用數據包身份驗證或加密。priv 關鍵字可啟用數據包加密和身份驗證。auth 或 priv 關鍵字不存在默認值。

接下來,我們在該組內創(chuàng)建了用戶admin,使用的SHA作為哈希算法,密鑰是Cisc0123;加密算法則使用的是AES256,密鑰同樣是Cisc0123。最后,與SNMP v2c相似,我們需要配置允許inside區(qū)域10.1.1.1 IP地址的admin用戶使用SNMP v3訪問該ASA設備。

完成SNMP v3配置后,我們可以通過如下SNMPv3 Python代碼進行測試:

frompysnmp.hlapiimport*


defsnmpv3_get(ip,oid,username,authkey,privkey,authprotocol,privprotocol,port=161):
#通過數字映射,對應SNMPv3使用的認證和加密算法
auth_map={'0':usmNoAuthProtocol,'1':usmHMACSHAAuthProtocol,'2':usmHMAC128SHA224AuthProtocol,
'3':usmHMAC192SHA256AuthProtocol,'4':usmHMAC256SHA384AuthProtocol,
'5':usmHMAC384SHA512AuthProtocol}

priv_map={'0':usmNoPrivProtocol,'1':usmAesCfb128Protocol,
'2':usmAesCfb192Protocol,'3':usmAesCfb256Protocol}

#varBinds是列表,列表中的每個元素的類型是ObjectType(該類型的對象表示MIBvariable)
errorindication,errorstatus,errorindex,varbinds=next(
getCmd(SnmpEngine(),
UsmUserData(userName=username,authKey=authkey,privKey=privkey,
authProtocol=auth_map.get(authprotocol),
privProtocol=priv_map.get(privprotocol)),
UdpTransportTarget((ip,port)),#配置目的地址和端口號
ContextData(),
ObjectType(ObjectIdentity(oid))#讀取的OID
)
)
#錯誤處理
iferrorindication:
print(errorindication)
eliferrorstatus:
print('%sat%s'%(
errorstatus,
errorindexandvarbinds[int(errorindex)-1][0]or'?'
)
)
#如果返回結果有多行,需要拼接后返回
result=""
forvarBindinvarbinds:
result=result+varBind.prettyPrint()#返回結果!
#返回的為一個元組,OID與字符串結果
returnresult.split("=")[0].strip(),result.split("=")[1].strip()


if__name__=="__main__":
ASA_oid={"CPUTotal1min":"1.3.6.1.4.1.9.9.109.1.1.1.1.7.1","MemoryUsed":"1.3.6.1.4.1.9.9.48.1.1.1.5.1",
"MemoryFree":"1.3.6.1.4.1.9.9.48.1.1.1.6.1","ifInOctets-G0-Outside":"1.3.6.1.2.1.2.2.1.10.3",
"ifOutOctets-G0-Outside":"1.3.6.1.2.1.2.2.1.16.3","ifInOctets-G1-Inside":"1.3.6.1.2.1.2.2.1.10.4",
"ifOutOctets-G1-Inside":"1.3.6.1.2.1.2.2.1.16.4","TotalIPSec":"1.3.6.1.4.1.9.9.392.1.3.26.0",
"L2LIPSec":"1.3.6.1.4.1.9.9.392.1.3.29.0","AnyConnectVPN":"1.3.6.1.4.1.9.9.392.1.3.35.0",
"WebVPN":"1.3.6.1.4.1.9.9.392.1.3.38.0"}

forkey,valueinASA_oid.items():
try:
print(key+':',snmpv3_get("10.1.102.254",value,'admin','Cisc0123','Cisc0123','1','3'))
exceptExceptionase:
print(e)

需要注意的是,這里我們對SNMP v3的加密和HASH算法進行了映射,后續(xù)只需要傳入相關的數字編號,即可設置SNMP v3的安全參數。最終的測試結果如圖2所示:

cfcca982-b10e-11ee-8b88-92fbcf53809c.png







審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • SNMP
    +關注

    關注

    0

    文章

    82

    瀏覽量

    29706
  • python
    +關注

    關注

    55

    文章

    4768

    瀏覽量

    84376
  • Hash算法
    +關注

    關注

    0

    文章

    43

    瀏覽量

    7379

原文標題:高級網絡工程師必備技能:使用Python PySNMP模塊獲取設備指標

文章出處:【微信號:網絡技術干貨圈,微信公眾號:網絡技術干貨圈】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    請問使用普通運放時如何獲取運放的增益誤差和增益非線性這些指標?

    AD8221這類的儀表放大器數據手冊中會有閉環(huán)的增益誤差和增益非線性度這樣的指標,但是像OP2177之類的普通運放的數據手冊中沒有這些參數,我在使用普通運放時如何獲取運放的增益誤差和增益非線性這樣的指標
    發(fā)表于 07-27 06:26

    Python獲取文件目錄函數模塊方法

    Python獲取文件夾和文件的路徑
    發(fā)表于 09-11 08:00

    Python入門之36常用第三方模塊獲取系統(tǒng)信息psutil

    Python入門】36常用第三方模塊獲取系統(tǒng)信息psutil
    發(fā)表于 07-16 06:31

    使用普通運放時如何獲取運放的增益誤差和增益非線性這樣的指標?

    AD8221這類的儀表放大器數據手冊中會有閉環(huán)的增益誤差和增益非線性度這樣的指標,但是像OP2177之類的普通運放的數據手冊中沒有這些參數,我在使用普通運放時如何獲取運放的增益誤差和增益非線性這樣的指標
    發(fā)表于 11-17 06:58

    解析Kubernetes監(jiān)控指標獲取方式對比

    。metric-server/heapster是從api-server中獲取CPU、內存使用率這種監(jiān)控指標,并把他們發(fā)送給存儲后端,如InfluxDB或云廠商,他當前的核心作用是:為HPA等組件提供決策指標支持
    的頭像 發(fā)表于 09-26 10:45 ?1426次閱讀

    python包、模塊和庫是什么

    1. 模塊 以 .py 為后綴的文件,我們稱之為 模塊,英文名 Module。 模塊讓你能夠有邏輯地組織你的 Python 代碼段,把相關的代碼分配到一個
    的頭像 發(fā)表于 03-09 16:47 ?2287次閱讀

    Python模塊Addict的安裝與使用

    Addit 是一個Python模塊,除了提供標準的字典語法外,Addit 生成的字典的值既可以使用屬性來獲取,也可以使用屬性進行設置。
    的頭像 發(fā)表于 06-21 16:14 ?2222次閱讀

    使用Python和PHP獲取天氣信息

    電子發(fā)燒友網站提供《使用Python和PHP獲取天氣信息.zip》資料免費下載
    發(fā)表于 01-04 11:03 ?1次下載
    使用<b class='flag-5'>Python</b>和PHP<b class='flag-5'>獲取</b>天氣信息

    Python-模塊與包

    模塊Python 程序架構的一個核心概念
    的頭像 發(fā)表于 02-16 14:55 ?739次閱讀
    <b class='flag-5'>Python</b>-<b class='flag-5'>模塊</b>與包

    python模塊屬性及字符串導入模塊介紹

    python可以通過點號或字典,獲取模塊屬性。 已經導入的模塊存放在sys.modules字典,通過getattr獲取
    的頭像 發(fā)表于 02-21 11:27 ?708次閱讀

    簡述python模塊import和from及all

    python指定導入目錄路徑,稱為包導入。 通過import和from導入包模塊。 通過**all**指定導入的模塊和導入的模塊屬性。 ## 1.1
    的頭像 發(fā)表于 02-21 14:20 ?1203次閱讀

    淺析python模塊創(chuàng)建和from及import使用

    python模塊通過用python程序編寫的.py文件即可創(chuàng)建,通過from及import語句導入模塊來使用。
    的頭像 發(fā)表于 02-21 14:44 ?785次閱讀

    Python中telnetlib模塊的基本使用

    telnetlib 是 Python 標準庫中的一個模塊,它提供了 Telnet 協(xié)議的客戶端功能。使用 telnetlib 模塊,我們可以在 Python 中編寫腳本來自動化 Tel
    的頭像 發(fā)表于 05-04 14:27 ?7863次閱讀

    yfinance:獲取數據的Python第三方模塊

    yfinance 是一個使用 Yahoo! 獲取數據的 Python 第三方模塊。它支持獲取最細到1分鐘級的歷史數據及股票基本面數據,是免費獲得美股分鐘級及以上粒度數據的不二之選。 1
    的頭像 發(fā)表于 10-21 14:32 ?2426次閱讀

    python如何導入模塊

    Python是一種強大的編程語言,它支持模塊化編程,使得開發(fā)者可以將代碼分解為可重用且獨立的模塊。模塊是一個包含函數、類和變量等定義的文件,我們可以使用import語句將這些
    的頭像 發(fā)表于 11-22 14:46 ?875次閱讀