diff options
author | Maran <maran.hidskes@gmail.com> | 2014-06-10 19:51:34 +0800 |
---|---|---|
committer | Maran <maran.hidskes@gmail.com> | 2014-06-10 19:51:34 +0800 |
commit | 771f64397fd8638e9a40a4b9ecc64a9b70d6f2e4 (patch) | |
tree | 5d6b82a5629d3ce24ebdd315d462ee8d6fac76f9 | |
parent | d8339fa29a884516166993a6d29caed59f32ca1b (diff) | |
download | go-tangerine-771f64397fd8638e9a40a4b9ecc64a9b70d6f2e4.tar go-tangerine-771f64397fd8638e9a40a4b9ecc64a9b70d6f2e4.tar.gz go-tangerine-771f64397fd8638e9a40a4b9ecc64a9b70d6f2e4.tar.bz2 go-tangerine-771f64397fd8638e9a40a4b9ecc64a9b70d6f2e4.tar.lz go-tangerine-771f64397fd8638e9a40a4b9ecc64a9b70d6f2e4.tar.xz go-tangerine-771f64397fd8638e9a40a4b9ecc64a9b70d6f2e4.tar.zst go-tangerine-771f64397fd8638e9a40a4b9ecc64a9b70d6f2e4.zip |
Stop peers when they don't respond to ping/pong. Might fix ethereum/go-ethereum#78
-rw-r--r-- | peer.go | 15 |
1 files changed, 12 insertions, 3 deletions
@@ -18,6 +18,8 @@ const ( outputBufferSize = 50 // Current protocol version ProtocolVersion = 17 + // Interval for ping/pong message + pingPongTimer = 30 * time.Second ) type DiscReason byte @@ -243,7 +245,7 @@ func (p *Peer) writeMessage(msg *ethwire.Msg) { err := ethwire.WriteMessage(p.conn, msg) if err != nil { - ethutil.Config.Log.Debugln("Can't send message:", err) + ethutil.Config.Log.Debugln("[PEER] Can't send message:", err) // Stop the client if there was an error writing to it p.Stop() return @@ -253,7 +255,7 @@ func (p *Peer) writeMessage(msg *ethwire.Msg) { // Outbound message handler. Outbound messages are handled here func (p *Peer) HandleOutbound() { // The ping timer. Makes sure that every 2 minutes a ping is send to the peer - pingTimer := time.NewTicker(30 * time.Second) + pingTimer := time.NewTicker(pingPongTimer) serviceTimer := time.NewTicker(5 * time.Minute) out: @@ -264,8 +266,14 @@ out: p.writeMessage(msg) p.lastSend = time.Now() - // Ping timer sends a ping to the peer each 2 minutes + // Ping timer case <-pingTimer.C: + timeSince := time.Since(time.Unix(p.lastPong, 0)) + if p.pingStartTime.IsZero() == false && timeSince > (pingPongTimer+10*time.Second) { + ethutil.Config.Log.Infof("[PEER] Peer did not respond to latest pong fast enough, it took %s, disconnecting.\n", timeSince) + p.Stop() + return + } p.writeMessage(ethwire.NewMessage(ethwire.MsgPingTy, "")) p.pingStartTime = time.Now() @@ -563,6 +571,7 @@ func (p *Peer) Stop() { // Pre-emptively remove the peer; don't wait for reaping. We already know it's dead if we are here p.ethereum.RemovePeer(p) + ethutil.Config.Log.Debugln("[PEER] Stopped peer:", p.conn.RemoteAddr()) } func (p *Peer) pushHandshake() error { |