diff options
author | Felix Lange <fjl@twurst.com> | 2015-02-19 23:53:52 +0800 |
---|---|---|
committer | Felix Lange <fjl@twurst.com> | 2015-02-19 23:54:54 +0800 |
commit | 3dbd32093cd1060c339b3351fbb676b8c7cc31f0 (patch) | |
tree | 41f92007b2e08aee7826f147fc8ac5ccdd1bf35a | |
parent | 1ec6190e866eeefd91ea82b31da9f94753685a4a (diff) | |
download | go-tangerine-3dbd32093cd1060c339b3351fbb676b8c7cc31f0.tar go-tangerine-3dbd32093cd1060c339b3351fbb676b8c7cc31f0.tar.gz go-tangerine-3dbd32093cd1060c339b3351fbb676b8c7cc31f0.tar.bz2 go-tangerine-3dbd32093cd1060c339b3351fbb676b8c7cc31f0.tar.lz go-tangerine-3dbd32093cd1060c339b3351fbb676b8c7cc31f0.tar.xz go-tangerine-3dbd32093cd1060c339b3351fbb676b8c7cc31f0.tar.zst go-tangerine-3dbd32093cd1060c339b3351fbb676b8c7cc31f0.zip |
p2p: enable devp2p ping
This should prevent connection drops.
-rw-r--r-- | p2p/peer.go | 37 |
1 files changed, 26 insertions, 11 deletions
diff --git a/p2p/peer.go b/p2p/peer.go index b9bf0fd73..fb027c834 100644 --- a/p2p/peer.go +++ b/p2p/peer.go @@ -21,6 +21,7 @@ const ( baseProtocolMaxMsgSize = 10 * 1024 * 1024 disconnectGracePeriod = 2 * time.Second + pingInterval = 15 * time.Second ) const ( @@ -118,19 +119,33 @@ func (p *Peer) run() DiscReason { p.startProtocols() go func() { readErr <- p.readLoop() }() + ping := time.NewTicker(pingInterval) + defer ping.Stop() + // Wait for an error or disconnect. var reason DiscReason - select { - case err := <-readErr: - // We rely on protocols to abort if there is a write error. It - // might be more robust to handle them here as well. - p.DebugDetailf("Read error: %v\n", err) - p.rw.Close() - return DiscNetworkError - - case err := <-p.protoErr: - reason = discReasonForError(err) - case reason = <-p.disc: +loop: + for { + select { + case <-ping.C: + go func() { + if err := EncodeMsg(p.rw, pingMsg, nil); err != nil { + p.protoErr <- err + return + } + }() + case err := <-readErr: + // We rely on protocols to abort if there is a write error. It + // might be more robust to handle them here as well. + p.DebugDetailf("Read error: %v\n", err) + p.rw.Close() + return DiscNetworkError + case err := <-p.protoErr: + reason = discReasonForError(err) + break loop + case reason = <-p.disc: + break loop + } } p.politeDisconnect(reason) |