diff options
author | Péter Szilágyi <peterke@gmail.com> | 2016-12-01 16:30:19 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-12-01 16:30:19 +0800 |
commit | 717d2f6f9e157bf6962ecadb9ffb30362c733239 (patch) | |
tree | a96ec24477fb0b353880f36731da8442566a9f37 | |
parent | 8cb95cb916e7e5c4f1595d976586999fcd9e209d (diff) | |
parent | 56b446190aedf7970c9532b1e428fbf1b5b94413 (diff) | |
download | go-tangerine-717d2f6f9e157bf6962ecadb9ffb30362c733239.tar.gz go-tangerine-717d2f6f9e157bf6962ecadb9ffb30362c733239.tar.zst go-tangerine-717d2f6f9e157bf6962ecadb9ffb30362c733239.zip |
Merge pull request #3390 from bas-vk/statsd-stop
ethstats: check if received event is valid
-rw-r--r-- | ethstats/ethstats.go | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/ethstats/ethstats.go b/ethstats/ethstats.go index b87f5ab78..a5fa84468 100644 --- a/ethstats/ethstats.go +++ b/ethstats/ethstats.go @@ -145,13 +145,21 @@ func (s *Service) loop() { glog.V(logger.Warn).Infof("Full stats report failed: %v", err) } case head := <-headSub.Chan(): + if head == nil { // node stopped + conn.Close() + return + } if err = s.reportBlock(out, head.Data.(core.ChainHeadEvent).Block); err != nil { glog.V(logger.Warn).Infof("Block stats report failed: %v", err) } if err = s.reportPending(out); err != nil { glog.V(logger.Warn).Infof("Post-block transaction stats report failed: %v", err) } - case <-txSub.Chan(): + case ev := <-txSub.Chan(): + if ev == nil { // node stopped + conn.Close() + return + } // Exhaust events to avoid reporting too frequently for exhausted := false; !exhausted; { select { |