Under ubuntu python-gevent kills packets #396
Labels
No Label
bug
build
dependencies
developers
documentation
duplicate
enhancement
formatting
invalid
legal
mobile
obsolete
packaging
performance
protocol
question
refactoring
regression
security
test
translation
usability
wontfix
No Milestone
No project
No Assignees
1 Participants
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: Bitmessage/PyBitmessage-2024-12-12#396
Loading…
Reference in New Issue
Block a user
No description provided.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
I'm running Ubuntu precise. I saw a message scroll past in the console suggesting that gevents could not be found but that it didn't matter. I installed python-gevent and could no longer establish sockets. Removing python-gevent fixed the problem so I've left it at that.
Vik :v)
This is very interesting. In a separate issue (#312) we're having trouble with gevent and multiprocess PoW. The underlying cause being that the multiprocessing module's transport layer expects socket to block but gevent patches the socket module to be non-blocking. But this is the first time I have heard of gevent causing problems for other bitmessage sockets... very weird. It's worth hunting around for places where child processes might cause funny libev states as is found in proof_of_work._doFastPow, but on cursory inspection I can't find anything that would do this elsewhere.
This is my first time working with gevent... can someone explain to me how it's helping pybitmessage in any way other than async IO? It's certainly convenient but the manner in which it achieves convenience seems really problematic from a reliability/maintainability standpoint. Maybe we should consider looking into other AIO options like ZeroMQ. Thoughts, anyone?
This code is gone now right? Should be able to close the issue.