mirror of https://github.com/rocboss/paopao-ce
parent
5dd7dc6cf5
commit
0c218fe944
@ -0,0 +1,57 @@
|
||||
// Copyright 2023 ROC. All rights reserved.
|
||||
// Use of this source code is governed by a MIT style
|
||||
// license that can be found in the LICENSE file.
|
||||
|
||||
package prometheus
|
||||
|
||||
import (
|
||||
"github.com/prometheus/client_golang/prometheus"
|
||||
"github.com/rocboss/paopao-ce/internal/conf"
|
||||
"github.com/rocboss/paopao-ce/internal/core"
|
||||
"github.com/sirupsen/logrus"
|
||||
)
|
||||
|
||||
type metrics struct {
|
||||
siteInfo *prometheus.GaugeVec
|
||||
ds core.DataService
|
||||
wc core.WebCache
|
||||
}
|
||||
|
||||
func (m *metrics) updateSiteInfo() {
|
||||
if onlineUserKeys, err := m.wc.Keys(conf.PrefixOnlineUser + "*"); err == nil {
|
||||
maxOnline := len(onlineUserKeys)
|
||||
m.siteInfo.With(prometheus.Labels{"name": "max_online"}).Set(float64(maxOnline))
|
||||
} else {
|
||||
logrus.Warnf("update promethues metrics[site_info_max_online] occurs error: %s", err)
|
||||
}
|
||||
if registerUserCount, err := m.ds.GetRegisterUserCount(); err == nil {
|
||||
m.siteInfo.With(prometheus.Labels{"name": "register_user_count"}).Set(float64(registerUserCount))
|
||||
} else {
|
||||
logrus.Warnf("update promethues metrics[site_info_register_user_count] occurs error: %s", err)
|
||||
}
|
||||
}
|
||||
|
||||
func (m *metrics) onUpdate() {
|
||||
logrus.Debugf("update promethues metrics job running")
|
||||
m.updateSiteInfo()
|
||||
}
|
||||
|
||||
func newMetrics(reg prometheus.Registerer, ds core.DataService, wc core.WebCache) *metrics {
|
||||
m := &metrics{
|
||||
siteInfo: prometheus.NewGaugeVec(
|
||||
prometheus.GaugeOpts{
|
||||
Namespace: "paopao",
|
||||
Subsystem: "site",
|
||||
Name: "simple_info",
|
||||
Help: "paopao-ce site simple information.",
|
||||
},
|
||||
[]string{
|
||||
// metric name
|
||||
"name",
|
||||
}),
|
||||
ds: ds,
|
||||
wc: wc,
|
||||
}
|
||||
reg.MustRegister(m.siteInfo)
|
||||
return m
|
||||
}
|
@ -0,0 +1,41 @@
|
||||
// Copyright 2023 ROC. All rights reserved.
|
||||
// Use of this source code is governed by a MIT style
|
||||
// license that can be found in the LICENSE file.
|
||||
|
||||
package prometheus
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
|
||||
"github.com/prometheus/client_golang/prometheus"
|
||||
"github.com/prometheus/client_golang/prometheus/collectors"
|
||||
"github.com/prometheus/client_golang/prometheus/promhttp"
|
||||
"github.com/robfig/cron/v3"
|
||||
"github.com/rocboss/paopao-ce/internal/conf"
|
||||
"github.com/rocboss/paopao-ce/internal/core"
|
||||
"github.com/rocboss/paopao-ce/internal/events"
|
||||
"github.com/sirupsen/logrus"
|
||||
)
|
||||
|
||||
func scheduleJobs(metrics *metrics) {
|
||||
spec := conf.JobManagerSetting.UpdateMetricsInterval
|
||||
schedule, err := cron.ParseStandard(spec)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
events.OnTask(schedule, metrics.onUpdate)
|
||||
logrus.Debug("shedule prometheus metrics update jobs complete")
|
||||
}
|
||||
|
||||
func NewHandler(ds core.DataService, wc core.WebCache) http.Handler {
|
||||
// Create non-global registry.
|
||||
registry := prometheus.NewRegistry()
|
||||
// Add go runtime metrics and process collectors.
|
||||
registry.MustRegister(
|
||||
collectors.NewGoCollector(),
|
||||
collectors.NewProcessCollector(collectors.ProcessCollectorOpts{}),
|
||||
)
|
||||
metrics := newMetrics(registry, ds, wc)
|
||||
scheduleJobs(metrics)
|
||||
return promhttp.HandlerFor(registry, promhttp.HandlerOpts{EnableOpenMetrics: true})
|
||||
}
|
@ -0,0 +1,64 @@
|
||||
// Copyright 2023 ROC. All rights reserved.
|
||||
// Use of this source code is governed by a MIT style
|
||||
// license that can be found in the LICENSE file.
|
||||
|
||||
package service
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"net/http"
|
||||
|
||||
"github.com/Masterminds/semver/v3"
|
||||
"github.com/fatih/color"
|
||||
"github.com/rocboss/paopao-ce/internal/conf"
|
||||
"github.com/rocboss/paopao-ce/internal/dao"
|
||||
"github.com/rocboss/paopao-ce/internal/dao/cache"
|
||||
"github.com/rocboss/paopao-ce/internal/metrics/prometheus"
|
||||
)
|
||||
|
||||
var (
|
||||
_ Service = (*metricsService)(nil)
|
||||
)
|
||||
|
||||
type metricsService struct {
|
||||
*baseHttpService
|
||||
}
|
||||
|
||||
func (s *metricsService) Name() string {
|
||||
return "MetricsService"
|
||||
}
|
||||
|
||||
func (s *metricsService) Version() *semver.Version {
|
||||
return semver.MustParse("v0.1.0")
|
||||
}
|
||||
|
||||
func (s *metricsService) OnInit() error {
|
||||
s.registerRoute(s, nil)
|
||||
return nil
|
||||
}
|
||||
|
||||
func (s *metricsService) String() string {
|
||||
return fmt.Sprintf("listen on %s\n", color.GreenString("http://%s:%s", conf.MetricsServerSetting.HttpIp, conf.MetricsServerSetting.HttpPort))
|
||||
}
|
||||
|
||||
func newMetricsService() Service {
|
||||
addr := conf.MetricsServerSetting.HttpIp + ":" + conf.MetricsServerSetting.HttpPort
|
||||
// notice this step just to register pprof server to start. don't share server with pprof.
|
||||
server := httpServers.from(addr, func() *httpServer {
|
||||
ds, wc := dao.DataService(), cache.NewWebCache()
|
||||
mux := http.NewServeMux()
|
||||
mux.Handle("/metrics", prometheus.NewHandler(ds, wc))
|
||||
return &httpServer{
|
||||
baseServer: newBaseServe(),
|
||||
server: &http.Server{
|
||||
Addr: addr,
|
||||
Handler: mux,
|
||||
},
|
||||
}
|
||||
})
|
||||
return &metricsService{
|
||||
baseHttpService: &baseHttpService{
|
||||
server: server,
|
||||
},
|
||||
}
|
||||
}
|
Loading…
Reference in new issue