【问题标题】:Listen traps with pysnmp用 pysnmp 监听陷阱
【发布时间】:2016-02-18 13:37:58
【问题描述】:

您好,我正在尝试使用 pysnmp doc 中的此代码侦听陷阱:

from pysnmp.carrier.asynsock.dispatch import AsynsockDispatcher
from pysnmp.carrier.asynsock.dgram import udp, udp6
from pyasn1.codec.ber import decoder
from pysnmp.proto import api

def cbFun(transportDispatcher, transportDomain, transportAddress, wholeMsg):
    print('cbFun is called')
    while wholeMsg:
    print('loop...')
        msgVer = int(api.decodeMessageVersion(wholeMsg))
        if msgVer in api.protoModules:
            pMod = api.protoModules[msgVer]
        else:
            print('Unsupported SNMP version %s' % msgVer)
            return
        reqMsg, wholeMsg = decoder.decode(
            wholeMsg, asn1Spec=pMod.Message(),
            )
        print('Notification message from %s:%s: ' % (
            transportDomain, transportAddress
            )
        )
        reqPDU = pMod.apiMessage.getPDU(reqMsg)
        if reqPDU.isSameTypeWith(pMod.TrapPDU()):
            if msgVer == api.protoVersion1:
                print('Enterprise: %s' % (
                    pMod.apiTrapPDU.getEnterprise(reqPDU).prettyPrint()
                    )
                )
                print('Agent Address: %s' % (
                    pMod.apiTrapPDU.getAgentAddr(reqPDU).prettyPrint()
                    )
                )
                print('Generic Trap: %s' % (
                    pMod.apiTrapPDU.getGenericTrap(reqPDU).prettyPrint()
                    )
                )
                print('Specific Trap: %s' % (
                    pMod.apiTrapPDU.getSpecificTrap(reqPDU).prettyPrint()
                    )
                )
                print('Uptime: %s' % (
                    pMod.apiTrapPDU.getTimeStamp(reqPDU).prettyPrint()
                    )
                )
                varBinds = pMod.apiTrapPDU.getVarBindList(reqPDU)
            else:
                varBinds = pMod.apiPDU.getVarBindList(reqPDU)
            print('Var-binds:')
            for oid, val in varBinds:
                print('%s = %s' % (oid.prettyPrint(), val.prettyPrint()))
    return wholeMsg

transportDispatcher = AsynsockDispatcher()

transportDispatcher.registerRecvCbFun(cbFun)

# UDP/IPv4
transportDispatcher.registerTransport(
    udp.domainName, udp.UdpSocketTransport().openServerMode(('localhost', 162))
)

# UDP/IPv6
transportDispatcher.registerTransport(
    udp6.domainName, udp6.Udp6SocketTransport().openServerMode(('::1', 162))
)

transportDispatcher.jobStarted(1)

try:
    # Dispatcher will never finish as job#1 never reaches zero
    print('run dispatcher')
    transportDispatcher.runDispatcher()
except:
    transportDispatcher.closeDispatcher()
    raise

但是当我用这个命令测试它时:

$ snmptrap -v1 -c public 127.0.0.1 1.3.6.1.4.1.20408.4.1.1.2
127.0.0.1 1 1 123 1.3.6.1.2.1.1.1.0 s test

什么都不显示。有人可以帮助我吗? 我想要的只是显示此接收器收到的陷阱。

编辑:我添加了一些打印,这是我运行程序时得到的:

C:\user\snmp\test>python fonction.py
rundispatcher
_

当我发送一个陷阱时,什么都没有显示。当我按 Ctrl+C 时,我得到:

C:\user\snmp\test>python fonction.py
rundispatcher
Traceback (most recent call last):
  File "fonction.py", line 73, in <module>
    transportDispatcher.runDispatcher()
  File "C:\user\snmp\test\pysnmp\carrier\asyncore\dispatch.py", line 37, in runDispatcher
    use_poll=True, map=self.__sockMap, count=1)
  File "C:\Python27\lib\asyncore.py", line 220, in loop
    poll_fun(timeout, map)
  File "C:\Python27\lib\asyncore.py", line 145, in poll
    r, w, e = select.select(r, w, e, timeout)
KeyboardInterrupt

【问题讨论】:

  • 您是否尝试在 cbFun 的开头添加一些测试打印以确保它被调用?如果是这样,请尝试在第一个之后立即放置一个。
  • 我试过了,cbFun 从来没有被调用过
  • 您的脚本可以在我的 Mac 上运行。会不会是防火墙问题?确保允许端口 162/udp。您可能需要启用 pysnmp 调试以查看是否有任何流量来自网络。
  • 感谢您的回复。端口 162/udp 已经打开。你能准确地告诉我你做了哪些步骤来使它起作用吗?我是 Python/pysnmp 的新手
  • 注意“print('loop...')”应该缩进。

标签: python pysnmp


【解决方案1】:

在 Windows 上,我发现我必须将侦听器地址从 'localhost' 更改为 ''。

netstat -a 然后显示它绑定为 0.0.0.0:162 而不是 127.0.0.0:162 并且它可以正常工作:

C:\>netstat -a | find ":162"
  UDP    0.0.0.0:162            *:*

【讨论】:

  • 同意监听端口更改它也适用于我。但我在第 51 行也遇到了问题:AttributeError: 'str' object has no attribute 'prettyPrint' 所以我必须取消注释 prettyPrint 调用,它为我解决了。我的pysnmp.__version__ 是 4.4.2。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-01-21
相关资源
最近更新 更多