forked from cerc-io/plugeth
p2p: enable devp2p ping
This should prevent connection drops.
This commit is contained in:
parent
1ec6190e86
commit
3dbd32093c
17
p2p/peer.go
17
p2p/peer.go
@ -21,6 +21,7 @@ const (
|
|||||||
baseProtocolMaxMsgSize = 10 * 1024 * 1024
|
baseProtocolMaxMsgSize = 10 * 1024 * 1024
|
||||||
|
|
||||||
disconnectGracePeriod = 2 * time.Second
|
disconnectGracePeriod = 2 * time.Second
|
||||||
|
pingInterval = 15 * time.Second
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
@ -118,19 +119,33 @@ func (p *Peer) run() DiscReason {
|
|||||||
p.startProtocols()
|
p.startProtocols()
|
||||||
go func() { readErr <- p.readLoop() }()
|
go func() { readErr <- p.readLoop() }()
|
||||||
|
|
||||||
|
ping := time.NewTicker(pingInterval)
|
||||||
|
defer ping.Stop()
|
||||||
|
|
||||||
// Wait for an error or disconnect.
|
// Wait for an error or disconnect.
|
||||||
var reason DiscReason
|
var reason DiscReason
|
||||||
|
loop:
|
||||||
|
for {
|
||||||
select {
|
select {
|
||||||
|
case <-ping.C:
|
||||||
|
go func() {
|
||||||
|
if err := EncodeMsg(p.rw, pingMsg, nil); err != nil {
|
||||||
|
p.protoErr <- err
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}()
|
||||||
case err := <-readErr:
|
case err := <-readErr:
|
||||||
// We rely on protocols to abort if there is a write error. It
|
// We rely on protocols to abort if there is a write error. It
|
||||||
// might be more robust to handle them here as well.
|
// might be more robust to handle them here as well.
|
||||||
p.DebugDetailf("Read error: %v\n", err)
|
p.DebugDetailf("Read error: %v\n", err)
|
||||||
p.rw.Close()
|
p.rw.Close()
|
||||||
return DiscNetworkError
|
return DiscNetworkError
|
||||||
|
|
||||||
case err := <-p.protoErr:
|
case err := <-p.protoErr:
|
||||||
reason = discReasonForError(err)
|
reason = discReasonForError(err)
|
||||||
|
break loop
|
||||||
case reason = <-p.disc:
|
case reason = <-p.disc:
|
||||||
|
break loop
|
||||||
|
}
|
||||||
}
|
}
|
||||||
p.politeDisconnect(reason)
|
p.politeDisconnect(reason)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user