mirror of https://github.com/hashicorp/consul
agent: add server raft.{last,applied}_index gauges (#6694)
These metrics are useful for : * Tracking the rate of update to the db * Allow to have a rough idea of when an index originatedpull/7260/head
parent
895a8a43b2
commit
68e0f6bf84
|
@ -543,7 +543,7 @@ func NewServerLogger(config *Config, logger hclog.InterceptLogger, tokens *token
|
||||||
}
|
}
|
||||||
|
|
||||||
// Start the metrics handlers.
|
// Start the metrics handlers.
|
||||||
go s.sessionStats()
|
go s.updateMetrics()
|
||||||
|
|
||||||
return s, nil
|
return s, nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -130,14 +130,16 @@ func (s *Server) clearAllSessionTimers() {
|
||||||
s.sessionTimers.StopAll()
|
s.sessionTimers.StopAll()
|
||||||
}
|
}
|
||||||
|
|
||||||
// sessionStats is a long running routine used to capture
|
// updateMetrics is a long running routine used to uddate a
|
||||||
// the number of active sessions being tracked
|
// number of server periodic metrics
|
||||||
func (s *Server) sessionStats() {
|
func (s *Server) updateMetrics() {
|
||||||
for {
|
for {
|
||||||
select {
|
select {
|
||||||
case <-time.After(5 * time.Second):
|
case <-time.After(time.Second):
|
||||||
metrics.SetGauge([]string{"session_ttl", "active"}, float32(s.sessionTimers.Len()))
|
metrics.SetGauge([]string{"session_ttl", "active"}, float32(s.sessionTimers.Len()))
|
||||||
|
|
||||||
|
metrics.SetGauge([]string{"raft", "applied_index"}, float32(s.raft.AppliedIndex()))
|
||||||
|
metrics.SetGauge([]string{"raft", "last_index"}, float32(s.raft.LastIndex()))
|
||||||
case <-s.shutdownCh:
|
case <-s.shutdownCh:
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue