2021-02-18 11:29:14 +00:00
|
|
|
package steward
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
|
|
|
"github.com/prometheus/client_golang/prometheus/promauto"
|
|
|
|
"github.com/prometheus/client_golang/prometheus/promhttp"
|
|
|
|
)
|
|
|
|
|
|
|
|
type metrics struct {
|
2021-02-18 13:27:53 +00:00
|
|
|
helloNodes map[node]struct{}
|
|
|
|
HelloNodes prometheus.Gauge
|
|
|
|
TotalRunningProcesses prometheus.Gauge
|
2021-02-18 11:29:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func newMetrics() *metrics {
|
|
|
|
m := metrics{
|
2021-02-18 13:27:53 +00:00
|
|
|
helloNodes: make(map[node]struct{}),
|
|
|
|
TotalRunningProcesses: promauto.NewGauge(prometheus.GaugeOpts{
|
2021-02-18 11:29:14 +00:00
|
|
|
Name: "total_running_processes",
|
|
|
|
Help: "The current number of total running processes",
|
|
|
|
}),
|
2021-02-18 13:27:53 +00:00
|
|
|
HelloNodes: promauto.NewGauge(prometheus.GaugeOpts{
|
|
|
|
Name: "hello_nodes",
|
|
|
|
Help: "The current number of total nodes who have said hello",
|
|
|
|
}),
|
2021-02-18 11:29:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return &m
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *server) startMetrics() {
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
for {
|
2021-02-18 13:27:53 +00:00
|
|
|
s.metrics.TotalRunningProcesses.Set(float64(len(s.processes)))
|
|
|
|
s.metrics.HelloNodes.Set(float64(len(s.metrics.helloNodes)))
|
2021-02-18 11:29:14 +00:00
|
|
|
time.Sleep(2 * time.Second)
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
|
|
|
http.Handle("/metrics", promhttp.Handler())
|
|
|
|
http.ListenAndServe(":2112", nil)
|
|
|
|
}
|