2021-01-20 01:21:15 +03:00
|
|
|
package meter
|
2020-08-18 10:27:50 +03:00
|
|
|
|
2020-11-18 16:50:41 +03:00
|
|
|
import (
|
2021-01-15 22:47:28 +03:00
|
|
|
"context"
|
|
|
|
|
2020-11-18 16:50:41 +03:00
|
|
|
"github.com/unistack-org/micro/v3/logger"
|
|
|
|
"github.com/unistack-org/micro/v3/metadata"
|
|
|
|
)
|
2020-08-29 17:44:49 +03:00
|
|
|
|
2020-08-18 10:27:50 +03:00
|
|
|
var (
|
2021-01-22 18:21:40 +03:00
|
|
|
// The Meter data will be made available on this port
|
|
|
|
DefaultAddress = ":9090"
|
|
|
|
// This is the endpoint where the Meter data will be made available ("/metrics" is the default)
|
|
|
|
DefaultPath = "/metrics"
|
2020-08-18 10:27:50 +03:00
|
|
|
// timingObjectives is the default spread of stats we maintain for timings / histograms:
|
2021-01-22 18:21:40 +03:00
|
|
|
//defaultTimingObjectives = map[float64]float64{0.0: 0, 0.5: 0.05, 0.75: 0.04, 0.90: 0.03, 0.95: 0.02, 0.98: 0.001, 1: 0}
|
2020-08-18 10:27:50 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
// Option powers the configuration for metrics implementations:
|
|
|
|
type Option func(*Options)
|
|
|
|
|
|
|
|
// Options for metrics implementations:
|
|
|
|
type Options struct {
|
2021-01-22 18:21:40 +03:00
|
|
|
Address string
|
|
|
|
Path string
|
|
|
|
Metadata metadata.Metadata
|
|
|
|
//TimingObjectives map[float64]float64
|
|
|
|
Logger logger.Logger
|
|
|
|
Context context.Context
|
2020-08-18 10:27:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// NewOptions prepares a set of options:
|
|
|
|
func NewOptions(opt ...Option) Options {
|
|
|
|
opts := Options{
|
2021-01-22 18:21:40 +03:00
|
|
|
Address: DefaultAddress,
|
|
|
|
Metadata: metadata.New(3), // 3 elements contains service name, version and id
|
|
|
|
Path: DefaultPath,
|
|
|
|
// TimingObjectives: defaultTimingObjectives,
|
|
|
|
Context: context.Background(),
|
|
|
|
Logger: logger.DefaultLogger,
|
2020-08-18 10:27:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, o := range opt {
|
|
|
|
o(&opts)
|
|
|
|
}
|
|
|
|
|
|
|
|
return opts
|
|
|
|
}
|
|
|
|
|
2021-01-15 22:47:28 +03:00
|
|
|
// Cntext sets the metrics context
|
|
|
|
func Context(ctx context.Context) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Context = ctx
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-22 18:21:40 +03:00
|
|
|
// Path used to serve metrics over HTTP
|
2020-08-18 10:27:50 +03:00
|
|
|
func Path(value string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Path = value
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-22 18:21:40 +03:00
|
|
|
// Address is the listen address to serve metrics
|
2020-08-18 10:27:50 +03:00
|
|
|
func Address(value string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Address = value
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-22 18:21:40 +03:00
|
|
|
// Metadata will be added to every metric
|
|
|
|
func Metadata(md metadata.Metadata) Option {
|
2020-08-18 10:27:50 +03:00
|
|
|
return func(o *Options) {
|
2021-01-22 18:21:40 +03:00
|
|
|
o.Metadata = metadata.Copy(md)
|
2020-08-18 10:27:50 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-22 18:21:40 +03:00
|
|
|
/*
|
2020-08-18 10:27:50 +03:00
|
|
|
// TimingObjectives defines the desired spread of statistics for histogram / timing metrics:
|
|
|
|
func TimingObjectives(value map[float64]float64) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.TimingObjectives = value
|
|
|
|
}
|
|
|
|
}
|
2021-01-22 18:21:40 +03:00
|
|
|
*/
|
2020-08-29 17:44:49 +03:00
|
|
|
|
|
|
|
// Logger sets the logger
|
|
|
|
func Logger(l logger.Logger) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Logger = l
|
|
|
|
}
|
|
|
|
}
|