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
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"net/http"
|
||||
|
||||
"github.com/tidwall/tile38/core"
|
||||
|
@ -18,7 +19,7 @@ var (
|
|||
"num_collections": prometheus.NewDesc("tile38_collections", "Total number of collections", nil, nil),
|
||||
"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),
|
||||
"num_hooks": prometheus.NewDesc("tile38_hooks", "", 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),
|
||||
|
@ -28,6 +29,10 @@ var (
|
|||
"cpus": prometheus.NewDesc("tile38_num_cpus", "", 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()
|
||||
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_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),
|
||||
"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{
|
||||
|
@ -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) {
|
||||
reg := prometheus.NewRegistry()
|
||||
|
||||
|
@ -84,8 +99,23 @@ func (s *Server) Collect(ch chan<- prometheus.Metric) {
|
|||
|
||||
ch <- prometheus.MustNewConstMetric(
|
||||
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
|
||||
|
|
|
@ -289,6 +289,7 @@ func Serve(host string, port int, dir string, http bool, metricsAddr string) err
|
|||
if metricsAddr != "" {
|
||||
log.Infof("Listening for metrics at: %s", metricsAddr)
|
||||
go func() {
|
||||
net_http.HandleFunc("/", server.MetricsIndexHandler)
|
||||
net_http.HandleFunc("/metrics", server.MetricsHandler)
|
||||
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