lnpeer: add some rate-limiting against ping flood#10665
Merged
SomberNight merged 2 commits intoMay 26, 2026
Conversation
f321x
reviewed
May 26, 2026
| await asyncio.sleep(min_delay - elapsed_since_last) | ||
| self._last_ping_recv_time = time.monotonic() | ||
| l = payload['num_pong_bytes'] | ||
| self.send_message('pong', byteslen=l) |
Member
There was a problem hiding this comment.
Maybe it would be good to drain the transport like this as well?
Suggested change
| self.send_message('pong', byteslen=l) | |
| msg = encode_msg('pong', byteslen=l) | |
| await self.transport.send_bytes_and_drain(msg) |
Otherwise, maybe a peer could just fill up our sockets outgoing buffer by ~234mb/h if they stop reading from their socket and keep sending pings every second.
Member
Author
There was a problem hiding this comment.
uuuuuu nice observation.
I don't know if such an attack would actually work though -- I would expect some kind of TCP timeout to get triggered from the OS. But maybe I am wrong?
In any case, let's do this, defense in depth.
Member
Author
There was a problem hiding this comment.
if they stop reading
I guess if they keep reading reeeeeeaaaalllyy slow, but send stuff at a steady pace, that might work, maybe.
A remote peer could send us lots of small ping messages, requesting large pong responses. This is cheap for them but potentially expensive for us. Does not seem too serious, but I think we could add some rate-limiting. note: There are many ways for a remote peer to inflate our incoming traffic usage, but the cost of that is usually shared between them and us (they need to send the data, we receive it).
might help against some memory exhaustion attacks f321x said: > maybe a peer could just fill up our sockets outgoing buffer by ~234mb/h > if they stop reading from their socket and keep sending pings every second. Co-authored-by: f321x <f@f321x.com>
33eb6e4 to
9b20657
Compare
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
A remote peer could send us lots of small ping messages, requesting large pong responses. This is cheap for them but potentially expensive for us. Does not seem too serious, but I think we could add some rate-limiting.
note: There are many ways for a remote peer to inflate our incoming traffic usage, but the cost of that is usually shared between them and us (they need to send the data, we receive it).