mirror of https://github.com/tidwall/tile38.git
add more metrics, add metrics index page
This commit is contained in:
parent
7ec4d58392
commit
6b0282d960
|
@ -1,6 +1,7 @@
|
||||||
package server
|
package server
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
||||||
"github.com/tidwall/tile38/core"
|
"github.com/tidwall/tile38/core"
|
||||||
|
@ -18,7 +19,7 @@ var (
|
||||||
"num_collections": prometheus.NewDesc("tile38_collections", "Total number of collections", nil, nil),
|
"num_collections": prometheus.NewDesc("tile38_collections", "Total number of collections", nil, nil),
|
||||||
"pid": prometheus.NewDesc("tile38_pid", "", nil, nil),
|
"pid": prometheus.NewDesc("tile38_pid", "", nil, nil),
|
||||||
"aof_size": prometheus.NewDesc("tile38_aof_size_bytes", "", nil, nil),
|
"aof_size": prometheus.NewDesc("tile38_aof_size_bytes", "", nil, nil),
|
||||||
"num_hooks": prometheus.NewDesc("tile38_hooks_total", "", nil, nil),
|
"num_hooks": prometheus.NewDesc("tile38_hooks", "", nil, nil),
|
||||||
"in_memory_size": prometheus.NewDesc("tile38_in_memory_size_bytes", "", 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_size": prometheus.NewDesc("tile38_heap_size_bytes", "", nil, nil),
|
||||||
"heap_released": prometheus.NewDesc("tile38_memory_reap_released_bytes", "", nil, nil),
|
"heap_released": prometheus.NewDesc("tile38_memory_reap_released_bytes", "", nil, nil),
|
||||||
|
@ -28,6 +29,10 @@ var (
|
||||||
"cpus": prometheus.NewDesc("tile38_num_cpus", "", nil, nil),
|
"cpus": prometheus.NewDesc("tile38_num_cpus", "", nil, nil),
|
||||||
"tile38_connected_clients": prometheus.NewDesc("tile38_connected_clients", "", nil, nil),
|
"tile38_connected_clients": prometheus.NewDesc("tile38_connected_clients", "", nil, nil),
|
||||||
|
|
||||||
|
"tile38_total_connections_received": prometheus.NewDesc("tile38_connections_received_total", "", nil, nil),
|
||||||
|
"tile38_total_messages_sent": prometheus.NewDesc("tile38_messages_sent_total", "", nil, nil),
|
||||||
|
"tile38_expired_keys": prometheus.NewDesc("tile38_expired_keys_total", "", nil, nil),
|
||||||
|
|
||||||
/*
|
/*
|
||||||
these metrics are NOT taken from basicStats() / extStats()
|
these metrics are NOT taken from basicStats() / extStats()
|
||||||
but are calculated independently
|
but are calculated independently
|
||||||
|
@ -37,6 +42,8 @@ var (
|
||||||
"collection_strings": prometheus.NewDesc("tile38_collection_strings", "Total number of strings 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),
|
"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),
|
"server_info": prometheus.NewDesc("tile38_server_info", "Server info", []string{"id", "version"}, nil),
|
||||||
|
"replication": prometheus.NewDesc("tile38_replication_info", "Replication info", []string{"role", "following", "caught_up", "caught_up_once"}, nil),
|
||||||
|
"start_time": prometheus.NewDesc("tile38_start_time_seconds", "", nil, nil),
|
||||||
}
|
}
|
||||||
|
|
||||||
cmdDurations = prometheus.NewSummaryVec(prometheus.SummaryOpts{
|
cmdDurations = prometheus.NewSummaryVec(prometheus.SummaryOpts{
|
||||||
|
@ -46,6 +53,14 @@ var (
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func (s *Server) MetricsIndexHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
|
w.Write([]byte(`<html><head>
|
||||||
|
<title>Tile38 ` + core.Version + `</title></head>
|
||||||
|
<body><h1>Tile38 ` + core.Version + `</h1>
|
||||||
|
<p><a href='/metrics'>Metrics</a></p>
|
||||||
|
</body></html>`))
|
||||||
|
}
|
||||||
|
|
||||||
func (s *Server) MetricsHandler(w http.ResponseWriter, r *http.Request) {
|
func (s *Server) MetricsHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
reg := prometheus.NewRegistry()
|
reg := prometheus.NewRegistry()
|
||||||
|
|
||||||
|
@ -84,8 +99,23 @@ func (s *Server) Collect(ch chan<- prometheus.Metric) {
|
||||||
|
|
||||||
ch <- prometheus.MustNewConstMetric(
|
ch <- prometheus.MustNewConstMetric(
|
||||||
metricDescriptions["server_info"],
|
metricDescriptions["server_info"],
|
||||||
prometheus.GaugeValue, 1.0, s.config.serverID(), core.Version,
|
prometheus.GaugeValue, 1.0,
|
||||||
)
|
s.config.serverID(), core.Version)
|
||||||
|
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
metricDescriptions["start_time"],
|
||||||
|
prometheus.GaugeValue, float64(s.started.Unix()))
|
||||||
|
|
||||||
|
replLbls := []string{"leader", "", "", ""}
|
||||||
|
if s.config.followHost() != "" {
|
||||||
|
replLbls = []string{"follower",
|
||||||
|
fmt.Sprintf("%s:%d", s.config.followHost(), s.config.followPort()),
|
||||||
|
fmt.Sprintf("%t", s.fcup), fmt.Sprintf("%t", s.fcuponce)}
|
||||||
|
}
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
metricDescriptions["replication"],
|
||||||
|
prometheus.GaugeValue, 1.0,
|
||||||
|
replLbls...)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
add objects/points/strings stats for each collection
|
add objects/points/strings stats for each collection
|
||||||
|
|
|
@ -289,6 +289,7 @@ func Serve(host string, port int, dir string, http bool, metricsAddr string) err
|
||||||
if metricsAddr != "" {
|
if metricsAddr != "" {
|
||||||
log.Infof("Listening for metrics at: %s", metricsAddr)
|
log.Infof("Listening for metrics at: %s", metricsAddr)
|
||||||
go func() {
|
go func() {
|
||||||
|
net_http.HandleFunc("/", server.MetricsIndexHandler)
|
||||||
net_http.HandleFunc("/metrics", server.MetricsHandler)
|
net_http.HandleFunc("/metrics", server.MetricsHandler)
|
||||||
log.Fatal(net_http.ListenAndServe(metricsAddr, nil))
|
log.Fatal(net_http.ListenAndServe(metricsAddr, nil))
|
||||||
}()
|
}()
|
||||||
|
|
|
@ -0,0 +1,8 @@
|
||||||
|
package server
|
||||||
|
|
||||||
|
import "testing"
|
||||||
|
|
||||||
|
func subTestInfo(t *testing.T, mc *mockServer) {
|
||||||
|
runStep(t, mc, "valid json", info_valid_json_test)
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue