-
Notifications
You must be signed in to change notification settings - Fork 23
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
bulkwalk loops forever if a buggy snmp server loops #94
Comments
Thanks for reporting this. It shouldn't be too complicated to add a simple loop detection for this case. |
Do you still have the device available? I might need your help with this to reliably reproduce this. |
Yes, I still have it available. Just let me know what I can do to help. |
If you could trigger the error with debug-logging enabled and send the output that would be a huge help. Something like this:
Considering that this is an endless loop you will need to CTRL-C this. This will print out hexdumps of all the packet exchanges between client and server. These hexdumps are what interests me primarily. They will help me dig deeper into the issue and reproduce it in a test-environment. |
fast hot fix xD /api/raw.py error_oid_loop = 300
for requested, retrieved in zip(oids, output):
if not OID(requested) < retrieved.oid:
try:
if error_oid_loop > 0:
stringified = unicode(retrieved.oid) # TODO remove when Py2 is dropped
except:
error_oid_loop -= 1
return output |
The new major release 2.0 has finally hit pypi. Albeit as pre-release for now so you have to opt-in by either running If you have the possibility to upgrade, could you give it a try and see how the device behaves? With luck I might be able to iron this out before flagging the release as "final". Note that this is a fairly big change due to the focus on asyncio. Depending on your project this may be a painful upgrade but I would appreciate the feedback. Docs (including overview of the upgrade) are available at https://puresnmp.readthedocs.io/en/develop/ |
Repeating or non-increasing OIDs In my case this error occurs for the standard IPv6 Mib on several Cisco boxes. This MIB is used like this: if you know an address, you can figure out the snmp-index of the port, which then could be used to decide if one manages the interface. The error itself is unfortunately not uncommon and I know that problem since years from different MIBs. And even system snmpwalk itself had the problem as well in the beginning. One can still switch the check off (option -Cc) Since routers and switches have configured ports, they should not be switched off or be rebooted (to avoid outages), that means that the OIDs are created at runtime, so there is always a good chance that something is wrong inside the OS of a router. Classically the error disappears after a reboot. So first the normal way with system command snmpwalk: Hint: The coding is a bit odd, so I added the version with numbers only as well. I changed the V6 address in the example for data security reasons ;)
puresnmp would run forever but since the oid is not appended it would not trash the memory at least. My proposal is just to check if the oid already exists: so in bulkget in site-packages/puresnmp/api/raw.py I propose this:
that would act pretty similar to snmpwalk .. although it is not really testing if the OID increases, of course. For increasing numbers I would need a comparison, I am not sure if I am smart enough to do that with python ... (but in C code it is written like that afaik). And of course I know that the function is called more than one time, but keeping the last value somewhere in a "static variable", which has to be reset before I do a new command? I dunno, I am not that familiar with your code, but at least wanted to help a bit. I can do tests of course, since classically I always have some boxes doing weird stuff. Hopefully I do not have to return to encapsuled snmpwalk commands again, I like the concept of puresnmp and it works great in all other cases. |
Issue Description
I have a device that is probably in some bad state. Doing a bulkwalk on an OID returns the expected varbinds, but then loops back to the second result and continues looping like this forever.
puresnmp only returns the results once, but then it never returns from bulkwalk() since it loops forever in the unfinished_oids loop.
I think what is needed is a check in multiwalk(): if yielded hasn't had anything added to it by the current multiget, then exit the unfinished_oids loop.
The text was updated successfully, but these errors were encountered: