2021-07-08 16:46:52 +03:00
|
|
|
package server
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
|
2021-05-10 05:06:33 +03:00
|
|
|
"github.com/tidwall/tile38/core"
|
|
|
|
|
2021-07-08 16:46:52 +03:00
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
|
|
|
"github.com/prometheus/client_golang/prometheus/promhttp"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
metricDescriptions = map[string]*prometheus.Desc{
|
|
|
|
/*
|
|
|
|
these metrics are taken from basicStats() / extStats()
|
|
|
|
by accessing the map and directly exporting the value found
|
|
|
|
*/
|
2021-05-10 17:54:38 +03:00
|
|
|
"num_collections": prometheus.NewDesc("tile38_collections", "Total number of collections", nil, nil),
|
2021-07-08 16:46:52 +03:00
|
|
|
"pid": prometheus.NewDesc("tile38_pid", "", nil, nil),
|
|
|
|
"aof_size": prometheus.NewDesc("tile38_aof_size_bytes", "", nil, nil),
|
|
|
|
"num_hooks": prometheus.NewDesc("tile38_hooks_total", "", nil, nil),
|
|
|
|
"in_memory_size": prometheus.NewDesc("tile38_in_memory_size_bytes", "", nil, nil),
|
|
|
|
"heap_size": prometheus.NewDesc("tile38_heap_size_bytes", "", nil, nil),
|
|
|
|
"heap_released": prometheus.NewDesc("tile38_memory_reap_released_bytes", "", nil, nil),
|
|
|
|
"max_heap_size": prometheus.NewDesc("tile38_memory_max_heap_size_bytes", "", nil, nil),
|
|
|
|
"avg_item_size": prometheus.NewDesc("tile38_avg_item_size_bytes", "", nil, nil),
|
|
|
|
"pointer_size": prometheus.NewDesc("tile38_pointer_size_bytes", "", nil, nil),
|
|
|
|
"cpus": prometheus.NewDesc("tile38_num_cpus", "", nil, nil),
|
|
|
|
"tile38_connected_clients": prometheus.NewDesc("tile38_connected_clients", "", nil, nil),
|
|
|
|
|
|
|
|
/*
|
|
|
|
these metrics are NOT taken from basicStats() / extStats()
|
|
|
|
but are calculated independently
|
|
|
|
*/
|
|
|
|
"collection_objects": prometheus.NewDesc("tile38_collection_objects", "Total number of objects per collection", []string{"col"}, nil),
|
|
|
|
"collection_points": prometheus.NewDesc("tile38_collection_points", "Total number of points per collection", []string{"col"}, nil),
|
|
|
|
"collection_strings": prometheus.NewDesc("tile38_collection_strings", "Total number of strings per collection", []string{"col"}, nil),
|
|
|
|
"collection_weight": prometheus.NewDesc("tile38_collection_weight_bytes", "Total weight of collection in bytes", []string{"col"}, nil),
|
|
|
|
"server_info": prometheus.NewDesc("tile38_server_info", "Server info", []string{"id", "version"}, nil),
|
|
|
|
}
|
|
|
|
|
|
|
|
cmdDurations = prometheus.NewSummaryVec(prometheus.SummaryOpts{
|
|
|
|
Name: "tile38_cmd_duration_seconds",
|
|
|
|
Objectives: map[float64]float64{0.5: 0.05, 0.9: 0.01, 0.95: 0.005, 0.99: 0.001},
|
|
|
|
}, []string{"cmd"},
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
func (s *Server) MetricsHandler(w http.ResponseWriter, r *http.Request) {
|
|
|
|
reg := prometheus.NewRegistry()
|
|
|
|
|
|
|
|
reg.MustRegister(
|
|
|
|
prometheus.NewProcessCollector(prometheus.ProcessCollectorOpts{}),
|
|
|
|
prometheus.NewGoCollector(),
|
|
|
|
prometheus.NewBuildInfoCollector(),
|
|
|
|
cmdDurations,
|
|
|
|
s,
|
|
|
|
)
|
|
|
|
|
2021-05-10 17:54:38 +03:00
|
|
|
promhttp.HandlerFor(reg, promhttp.HandlerOpts{}).ServeHTTP(w, r)
|
2021-07-08 16:46:52 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Server) Describe(ch chan<- *prometheus.Desc) {
|
|
|
|
for _, desc := range metricDescriptions {
|
|
|
|
ch <- desc
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Server) Collect(ch chan<- prometheus.Metric) {
|
2021-05-10 17:54:38 +03:00
|
|
|
s.mu.RLock()
|
|
|
|
defer s.mu.RUnlock()
|
|
|
|
|
2021-07-08 16:46:52 +03:00
|
|
|
m := make(map[string]interface{})
|
|
|
|
s.basicStats(m)
|
|
|
|
s.extStats(m)
|
|
|
|
|
|
|
|
for metric, descr := range metricDescriptions {
|
|
|
|
if val, ok := m[metric].(int); ok {
|
|
|
|
ch <- prometheus.MustNewConstMetric(descr, prometheus.GaugeValue, float64(val))
|
|
|
|
} else if val, ok := m[metric].(float64); ok {
|
|
|
|
ch <- prometheus.MustNewConstMetric(descr, prometheus.GaugeValue, val)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-10 05:06:33 +03:00
|
|
|
ch <- prometheus.MustNewConstMetric(
|
|
|
|
metricDescriptions["server_info"],
|
|
|
|
prometheus.GaugeValue, 1.0, s.config.serverID(), core.Version,
|
|
|
|
)
|
|
|
|
|
2021-07-08 16:46:52 +03:00
|
|
|
/*
|
2021-05-10 17:54:38 +03:00
|
|
|
add objects/points/strings stats for each collection
|
2021-07-08 16:46:52 +03:00
|
|
|
*/
|
|
|
|
s.cols.Ascend(nil, func(v interface{}) bool {
|
|
|
|
c := v.(*collectionKeyContainer)
|
|
|
|
ch <- prometheus.MustNewConstMetric(
|
|
|
|
metricDescriptions["collection_objects"],
|
|
|
|
prometheus.GaugeValue,
|
|
|
|
float64(c.col.Count()),
|
|
|
|
c.key,
|
|
|
|
)
|
|
|
|
ch <- prometheus.MustNewConstMetric(
|
|
|
|
metricDescriptions["collection_points"],
|
|
|
|
prometheus.GaugeValue,
|
|
|
|
float64(c.col.PointCount()),
|
|
|
|
c.key,
|
|
|
|
)
|
|
|
|
ch <- prometheus.MustNewConstMetric(
|
|
|
|
metricDescriptions["collection_strings"],
|
|
|
|
prometheus.GaugeValue,
|
|
|
|
float64(c.col.StringCount()),
|
|
|
|
c.key,
|
|
|
|
)
|
|
|
|
ch <- prometheus.MustNewConstMetric(
|
|
|
|
metricDescriptions["collection_weight"],
|
|
|
|
prometheus.GaugeValue,
|
|
|
|
float64(c.col.TotalWeight()),
|
|
|
|
c.key,
|
|
|
|
)
|
|
|
|
return true
|
|
|
|
})
|
|
|
|
}
|