我正在尝试编写简单的python应用程序来发送SNMP陷阱。我已经编写了MIB表并向localhost发送陷阱工作正常。
from pysnmp.entity.rfc3413.oneliner import ntforg
ntfOrg = ntforg.NotificationOriginator()
errorIndication = ntfOrg.sendNotification(
ntforg.CommunityData('public'),
ntforg.UdpTransportTarget(('localhost', 162)),
'trap',
ntforg.MibVariable('MY-MIB', 'my_trap'),
( ntforg.MibVariable('MY-MIB', 'my_trap_var'), 0xAABBCCDD )
)
if errorIndication:
print('Notification not sent: %s' % errorIndocation)
现在我需要修改代码以将陷阱发送到私有子网。
我有它的IP地址,子网掩码和网关IP。 假设:
IP:20.40.34.14
子网掩码:255.255.255.224
Gateway:20.40.34.10
有没有办法通过适当的ntforg.UdpTransportTarget(...)
参数来解决这个问题?我查找了这个类的源代码(target.py
),并在内部使用:
socket.getaddrinfo(transportAddr[0], # localhost in example
transportAddr[1], # 162 in example
socket.AF_INET,
socket.SOCK_DGRAM,
socket.IPPROTO_UDP)[0][4][:2]
答案 0 :(得分:0)
这不是特定于SNMP的。可能与IP路由更相关。
当你在主机之间获得IP连接时,只需将20.40.34.14放入UdpTransportTarget即可。只要UDP / 162数据包可以到达您的通知接收器主机,这应该可以正常工作。
还可以选择发送广播TRAP。