mirror of
https://github.com/LBRYFoundation/tracker.git
synced 2025-08-23 17:47:29 +00:00
implement prometheus server
This commit is contained in:
parent
0dfc26caea
commit
33d6b1cd12
3 changed files with 105 additions and 2 deletions
|
@ -16,6 +16,7 @@ import (
|
||||||
"github.com/chihaya/chihaya/tracker"
|
"github.com/chihaya/chihaya/tracker"
|
||||||
|
|
||||||
_ "github.com/chihaya/chihaya/server/http"
|
_ "github.com/chihaya/chihaya/server/http"
|
||||||
|
_ "github.com/chihaya/chihaya/server/prometheus"
|
||||||
_ "github.com/chihaya/chihaya/server/store"
|
_ "github.com/chihaya/chihaya/server/store"
|
||||||
_ "github.com/chihaya/chihaya/server/store/memory"
|
_ "github.com/chihaya/chihaya/server/store/memory"
|
||||||
_ "github.com/chihaya/chihaya/server/store/middleware/client"
|
_ "github.com/chihaya/chihaya/server/store/middleware/client"
|
||||||
|
|
|
@ -7,10 +7,12 @@ chihaya:
|
||||||
announce: 10m
|
announce: 10m
|
||||||
min_announce: 5m
|
min_announce: 5m
|
||||||
announce_middleware:
|
announce_middleware:
|
||||||
|
# These are currently fake values
|
||||||
- prometheus
|
- prometheus
|
||||||
- store_client_validation
|
- store_client_validation
|
||||||
- store_create_on_announce
|
- store_create_on_announce
|
||||||
scrape_middleware:
|
scrape_middleware:
|
||||||
|
# These are currently fake values
|
||||||
- prometheus
|
- prometheus
|
||||||
- store_client_validation
|
- store_client_validation
|
||||||
|
|
||||||
|
@ -28,13 +30,20 @@ chihaya:
|
||||||
gcAfter: 30m
|
gcAfter: 30m
|
||||||
shards: 1
|
shards: 1
|
||||||
|
|
||||||
- name: http
|
- name: prometheus
|
||||||
config:
|
config:
|
||||||
addr: localhost:6881
|
addr: localhost:6881
|
||||||
|
shutdown_timeout: 10s
|
||||||
|
read_timeout: 10s
|
||||||
|
write_timeout: 10s
|
||||||
|
|
||||||
|
- name: http
|
||||||
|
config:
|
||||||
|
addr: localhost:6882
|
||||||
request_timeout: 10s
|
request_timeout: 10s
|
||||||
read_timeout: 10s
|
read_timeout: 10s
|
||||||
write_timeout: 10s
|
write_timeout: 10s
|
||||||
|
|
||||||
- name: udp
|
- name: udp
|
||||||
config:
|
config:
|
||||||
addr: localhost:6882
|
addr: localhost:6883
|
||||||
|
|
93
server/prometheus/prometheus.go
Normal file
93
server/prometheus/prometheus.go
Normal file
|
@ -0,0 +1,93 @@
|
||||||
|
// Copyright 2016 The Chihaya Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed by the BSD 2-Clause license,
|
||||||
|
// which can be found in the LICENSE file.
|
||||||
|
|
||||||
|
// Package prometheus implements a chihaya Server for serving metrics to
|
||||||
|
// Prometheus.
|
||||||
|
package prometheus
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"net/http"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
|
"github.com/tylerb/graceful"
|
||||||
|
"gopkg.in/yaml.v2"
|
||||||
|
|
||||||
|
"github.com/chihaya/chihaya"
|
||||||
|
"github.com/chihaya/chihaya/server"
|
||||||
|
"github.com/chihaya/chihaya/tracker"
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
server.Register("prometheus", constructor)
|
||||||
|
}
|
||||||
|
|
||||||
|
func constructor(srvcfg *chihaya.ServerConfig, tkr *tracker.Tracker) (server.Server, error) {
|
||||||
|
cfg, err := NewServerConfig(srvcfg)
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.New("prometheus: invalid config: " + err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
return &Server{
|
||||||
|
cfg: cfg,
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// ServerConfig represents the configuration options for a
|
||||||
|
// PrometheusServer.
|
||||||
|
type ServerConfig struct {
|
||||||
|
Addr string `yaml:"addr"`
|
||||||
|
ShutdownTimeout time.Duration `yaml:"shutdown_timeout"`
|
||||||
|
ReadTimeout time.Duration `yaml:"read_timeout"`
|
||||||
|
WriteTimeout time.Duration `yaml:"write_timeout"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewServerConfig marshals a chihaya.ServerConfig and unmarshals it
|
||||||
|
// into a more specific prometheus ServerConfig.
|
||||||
|
func NewServerConfig(srvcfg *chihaya.ServerConfig) (*ServerConfig, error) {
|
||||||
|
bytes, err := yaml.Marshal(srvcfg.Config)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
var cfg ServerConfig
|
||||||
|
err = yaml.Unmarshal(bytes, &cfg)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return &cfg, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Server implements a chihaya Server for serving metrics to Prometheus.
|
||||||
|
type Server struct {
|
||||||
|
cfg *ServerConfig
|
||||||
|
grace *graceful.Server
|
||||||
|
stopped bool
|
||||||
|
}
|
||||||
|
|
||||||
|
var _ server.Server = &Server{}
|
||||||
|
|
||||||
|
func (s *Server) Start() {
|
||||||
|
s.grace = &graceful.Server{
|
||||||
|
Server: &http.Server{
|
||||||
|
Addr: s.cfg.Addr,
|
||||||
|
Handler: prometheus.Handler(),
|
||||||
|
ReadTimeout: s.cfg.ReadTimeout,
|
||||||
|
WriteTimeout: s.cfg.WriteTimeout,
|
||||||
|
},
|
||||||
|
Timeout: s.cfg.ShutdownTimeout,
|
||||||
|
NoSignalHandling: true,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *Server) Stop() {
|
||||||
|
s.grace.Stop(s.cfg.ShutdownTimeout)
|
||||||
|
stopChan := s.grace.StopChan()
|
||||||
|
|
||||||
|
// Block until the graceful server shuts down and closes this channel.
|
||||||
|
for range stopChan {
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue