Skip to content

Commit

Permalink
p2p/protocols: fix possible metrics loss in AccountingMetrics (#18956)
Browse files Browse the repository at this point in the history
  • Loading branch information
janos authored and nonsense committed Jan 29, 2019
1 parent a0ac3b6 commit 74c3890
Showing 1 changed file with 15 additions and 0 deletions.
15 changes: 15 additions & 0 deletions p2p/protocols/reporter.go
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,13 @@ type AccountingMetrics struct {
//for a graceful cleanup
func (am *AccountingMetrics) Close() {
close(am.reporter.quit)
// wait for reporter loop to finish saving metrics
// before reporter database is closed
select {
case <-time.After(10 * time.Second):
log.Error("accounting metrics reporter timeout")
case <-am.reporter.done:
}
am.reporter.db.Close()
}

Expand All @@ -46,6 +53,7 @@ type reporter struct {
interval time.Duration //duration at which the reporter will persist metrics
db *leveldb.DB //the actual DB
quit chan struct{} //quit the reporter loop
done chan struct{} //signal that reporter loop is done
}

//NewMetricsDB creates a new LevelDB instance used to persist metrics defined
Expand Down Expand Up @@ -92,6 +100,7 @@ func NewAccountingMetrics(r metrics.Registry, d time.Duration, path string) *Acc
interval: d,
db: db,
quit: make(chan struct{}),
done: make(chan struct{}),
}

//run the go routine
Expand All @@ -106,6 +115,9 @@ func NewAccountingMetrics(r metrics.Registry, d time.Duration, path string) *Acc

//run is the goroutine which periodically sends the metrics to the configured LevelDB
func (r *reporter) run() {
// signal that the reporter loop is done
defer close(r.done)

intervalTicker := time.NewTicker(r.interval)

for {
Expand All @@ -121,6 +133,9 @@ func (r *reporter) run() {
}
case <-r.quit:
//graceful shutdown
if err := r.save(); err != nil {
log.Error("unable to send metrics to LevelDB", "err", err)
}
return
}
}
Expand Down

0 comments on commit 74c3890

Please sign in to comment.