ethstats: stop report ticker in each loop cycle #21070 (#21071)

Co-authored-by: Hao Duan <duan.hao@hyperchain.cn>
release/1.9
Hao Duan 5 years ago committed by GitHub
parent d02301f758
commit a188a1e150
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 23
      ethstats/ethstats.go

@ -154,7 +154,7 @@ func (s *Service) loop() {
txSub := txpool.SubscribeNewTxsEvent(txEventCh) txSub := txpool.SubscribeNewTxsEvent(txEventCh)
defer txSub.Unsubscribe() defer txSub.Unsubscribe()
// Start a goroutine that exhausts the subsciptions to avoid events piling up // Start a goroutine that exhausts the subscriptions to avoid events piling up
var ( var (
quitCh = make(chan struct{}) quitCh = make(chan struct{})
headCh = make(chan *types.Block, 1) headCh = make(chan *types.Block, 1)
@ -194,16 +194,17 @@ func (s *Service) loop() {
} }
close(quitCh) close(quitCh)
}() }()
// Resolve the URL, defaulting to TLS, but falling back to none too
path := fmt.Sprintf("%s/api", s.host)
urls := []string{path}
// url.Parse and url.IsAbs is unsuitable (https://github.com/golang/go/issues/19779)
if !strings.Contains(path, "://") {
urls = []string{"wss://" + path, "ws://" + path}
}
// Loop reporting until termination // Loop reporting until termination
for { for {
// Resolve the URL, defaulting to TLS, but falling back to none too
path := fmt.Sprintf("%s/api", s.host)
urls := []string{path}
// url.Parse and url.IsAbs is unsuitable (https://github.com/golang/go/issues/19779)
if !strings.Contains(path, "://") {
urls = []string{"wss://" + path, "ws://" + path}
}
// Establish a websocket connection to the server on any supported URL // Establish a websocket connection to the server on any supported URL
var ( var (
conn *websocket.Conn conn *websocket.Conn
@ -240,11 +241,12 @@ func (s *Service) loop() {
} }
// Keep sending status updates until the connection breaks // Keep sending status updates until the connection breaks
fullReport := time.NewTicker(15 * time.Second) fullReport := time.NewTicker(15 * time.Second)
defer fullReport.Stop()
for err == nil { for err == nil {
select { select {
case <-quitCh: case <-quitCh:
fullReport.Stop()
// Make sure the connection is closed
conn.Close() conn.Close()
return return
@ -269,6 +271,7 @@ func (s *Service) loop() {
} }
} }
} }
fullReport.Stop()
// Make sure the connection is closed // Make sure the connection is closed
conn.Close() conn.Close()
} }

Loading…
Cancel
Save