ipld-eth-server/pkg/prom/prom.go

64 lines
1.4 KiB
Go
Raw Normal View History

2020-10-19 13:07:29 +00:00
package prom
import (
"github.com/jmoiron/sqlx"
"github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/client_golang/prometheus/promauto"
2020-10-19 13:07:29 +00:00
)
const (
namespace = "ipld_eth_server"
subsystemHTTP = "http"
subsystemWS = "ws"
subsystemIPC = "ipc"
2020-10-19 13:07:29 +00:00
)
var (
metrics bool
httpCount prometheus.Counter
httpDuration prometheus.Histogram
2020-10-19 20:00:09 +00:00
wsCount prometheus.Gauge
ipcCount prometheus.Gauge
2020-10-19 13:07:29 +00:00
)
// Init module initialization
func Init() {
metrics = true
httpCount = promauto.NewCounter(prometheus.CounterOpts{
Namespace: namespace,
Subsystem: subsystemHTTP,
Name: "count",
2020-10-19 20:00:09 +00:00
Help: "http request count",
})
httpDuration = promauto.NewHistogram(prometheus.HistogramOpts{
Namespace: namespace,
Subsystem: subsystemHTTP,
Name: "duration",
2020-10-19 20:00:09 +00:00
Help: "http request duration",
})
2020-10-19 20:00:09 +00:00
wsCount = promauto.NewGauge(prometheus.GaugeOpts{
Namespace: namespace,
Subsystem: subsystemWS,
Name: "count",
2020-10-19 20:00:09 +00:00
Help: "websocket conntection count",
})
2020-10-19 20:00:09 +00:00
ipcCount = promauto.NewGauge(prometheus.GaugeOpts{
Namespace: namespace,
Subsystem: subsystemIPC,
Name: "count",
2020-10-19 20:00:09 +00:00
Help: "unix socket connection count",
})
2020-10-19 13:07:29 +00:00
}
// RegisterDBCollector create metric colletor for given connection
func RegisterDBCollector(name string, db *sqlx.DB) {
if metrics {
prometheus.Register(NewDBStatsCollector(name, db))
}
}