discovery: add config label to discovered targets metric (#4753)

* discovery: add labels to discovered targets metric

Signed-off-by: Simon Pasquier <spasquie@redhat.com>
This commit is contained in:
Simon Pasquier 2018-10-18 17:46:59 +02:00 committed by Brian Brazil
parent 105ed5c112
commit a30348f1a4
2 changed files with 29 additions and 8 deletions

View File

@ -260,10 +260,10 @@ func main() {
notifier = notifier.NewManager(&cfg.notifier, log.With(logger, "component", "notifier")) notifier = notifier.NewManager(&cfg.notifier, log.With(logger, "component", "notifier"))
ctxScrape, cancelScrape = context.WithCancel(context.Background()) ctxScrape, cancelScrape = context.WithCancel(context.Background())
discoveryManagerScrape = discovery.NewManager(ctxScrape, log.With(logger, "component", "discovery manager scrape")) discoveryManagerScrape = discovery.NewManager(ctxScrape, log.With(logger, "component", "discovery manager scrape"), discovery.Name("scrape"))
ctxNotify, cancelNotify = context.WithCancel(context.Background()) ctxNotify, cancelNotify = context.WithCancel(context.Background())
discoveryManagerNotify = discovery.NewManager(ctxNotify, log.With(logger, "component", "discovery manager notify")) discoveryManagerNotify = discovery.NewManager(ctxNotify, log.With(logger, "component", "discovery manager notify"), discovery.Name("notify"))
scrapeManager = scrape.NewManager(log.With(logger, "component", "scrape manager"), fanoutStorage) scrapeManager = scrape.NewManager(log.With(logger, "component", "scrape manager"), fanoutStorage)

View File

@ -47,11 +47,12 @@ var (
Help: "Total number of service discovery configurations that failed to load.", Help: "Total number of service discovery configurations that failed to load.",
}, },
) )
discoveredTargets = prometheus.NewGauge( discoveredTargets = prometheus.NewGaugeVec(
prometheus.GaugeOpts{ prometheus.GaugeOpts{
Name: "prometheus_sd_discovered_targets", Name: "prometheus_sd_discovered_targets",
Help: "Current number of discovered targets.", Help: "Current number of discovered targets.",
}, },
[]string{"name", "config"},
) )
receivedUpdates = prometheus.NewCounter( receivedUpdates = prometheus.NewCounter(
prometheus.CounterOpts{ prometheus.CounterOpts{
@ -106,12 +107,12 @@ type provider struct {
config interface{} config interface{}
} }
// NewManager is the Discovery Manager constructor // NewManager is the Discovery Manager constructor.
func NewManager(ctx context.Context, logger log.Logger) *Manager { func NewManager(ctx context.Context, logger log.Logger, options ...func(*Manager)) *Manager {
if logger == nil { if logger == nil {
logger = log.NewNopLogger() logger = log.NewNopLogger()
} }
return &Manager{ mgr := &Manager{
logger: logger, logger: logger,
syncCh: make(chan map[string][]*targetgroup.Group), syncCh: make(chan map[string][]*targetgroup.Group),
targets: make(map[poolKey]map[string]*targetgroup.Group), targets: make(map[poolKey]map[string]*targetgroup.Group),
@ -120,12 +121,26 @@ func NewManager(ctx context.Context, logger log.Logger) *Manager {
updatert: 5 * time.Second, updatert: 5 * time.Second,
triggerSend: make(chan struct{}, 1), triggerSend: make(chan struct{}, 1),
} }
for _, option := range options {
option(mgr)
}
return mgr
}
// Name sets the name of the manager.
func Name(n string) func(*Manager) {
return func(m *Manager) {
m.mtx.Lock()
defer m.mtx.Unlock()
m.name = n
}
} }
// Manager maintains a set of discovery providers and sends each update to a map channel. // Manager maintains a set of discovery providers and sends each update to a map channel.
// Targets are grouped by the target set name. // Targets are grouped by the target set name.
type Manager struct { type Manager struct {
logger log.Logger logger log.Logger
name string
mtx sync.RWMutex mtx sync.RWMutex
ctx context.Context ctx context.Context
discoverCancel []context.CancelFunc discoverCancel []context.CancelFunc
@ -166,9 +181,15 @@ func (m *Manager) ApplyConfig(cfg map[string]sd_config.ServiceDiscoveryConfig) e
m.mtx.Lock() m.mtx.Lock()
defer m.mtx.Unlock() defer m.mtx.Unlock()
for pk := range m.targets {
if _, ok := cfg[pk.setName]; !ok {
discoveredTargets.DeleteLabelValues(m.name, pk.setName)
}
}
m.cancelDiscoverers() m.cancelDiscoverers()
for name, scfg := range cfg { for name, scfg := range cfg {
m.registerProviders(scfg, name) m.registerProviders(scfg, name)
discoveredTargets.WithLabelValues(m.name, name).Set(0)
} }
for _, prov := range m.providers { for _, prov := range m.providers {
m.startProvider(m.ctx, prov) m.startProvider(m.ctx, prov)
@ -279,16 +300,16 @@ func (m *Manager) allGroups() map[string][]*targetgroup.Group {
defer m.mtx.Unlock() defer m.mtx.Unlock()
tSets := map[string][]*targetgroup.Group{} tSets := map[string][]*targetgroup.Group{}
var n int
for pkey, tsets := range m.targets { for pkey, tsets := range m.targets {
var n int
for _, tg := range tsets { for _, tg := range tsets {
// Even if the target group 'tg' is empty we still need to send it to the 'Scrape manager' // Even if the target group 'tg' is empty we still need to send it to the 'Scrape manager'
// to signal that it needs to stop all scrape loops for this target set. // to signal that it needs to stop all scrape loops for this target set.
tSets[pkey.setName] = append(tSets[pkey.setName], tg) tSets[pkey.setName] = append(tSets[pkey.setName], tg)
n += len(tg.Targets) n += len(tg.Targets)
} }
discoveredTargets.WithLabelValues(m.name, pkey.setName).Set(float64(n))
} }
discoveredTargets.Set(float64(n))
return tSets return tSets
} }