2017-11-25 05:13:54 -08:00
|
|
|
// Copyright 2013 The Prometheus Authors
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
package retrieval
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/go-kit/kit/log"
|
|
|
|
"github.com/go-kit/kit/log/level"
|
|
|
|
|
|
|
|
"github.com/prometheus/prometheus/config"
|
Refactor SD configuration to remove `config` dependency (#3629)
* refactor: move targetGroup struct and CheckOverflow() to their own package
* refactor: move auth and security related structs to a utility package, fix import error in utility package
* refactor: Azure SD, remove SD struct from config
* refactor: DNS SD, remove SD struct from config into dns package
* refactor: ec2 SD, move SD struct from config into the ec2 package
* refactor: file SD, move SD struct from config to file discovery package
* refactor: gce, move SD struct from config to gce discovery package
* refactor: move HTTPClientConfig and URL into util/config, fix import error in httputil
* refactor: consul, move SD struct from config into consul discovery package
* refactor: marathon, move SD struct from config into marathon discovery package
* refactor: triton, move SD struct from config to triton discovery package, fix test
* refactor: zookeeper, move SD structs from config to zookeeper discovery package
* refactor: openstack, remove SD struct from config, move into openstack discovery package
* refactor: kubernetes, move SD struct from config into kubernetes discovery package
* refactor: notifier, use targetgroup package instead of config
* refactor: tests for file, marathon, triton SD - use targetgroup package instead of config.TargetGroup
* refactor: retrieval, use targetgroup package instead of config.TargetGroup
* refactor: storage, use config util package
* refactor: discovery manager, use targetgroup package instead of config.TargetGroup
* refactor: use HTTPClient and TLS config from configUtil instead of config
* refactor: tests, use targetgroup package instead of config.TargetGroup
* refactor: fix tagetgroup.Group pointers that were removed by mistake
* refactor: openstack, kubernetes: drop prefixes
* refactor: remove import aliases forced due to vscode bug
* refactor: move main SD struct out of config into discovery/config
* refactor: rename configUtil to config_util
* refactor: rename yamlUtil to yaml_config
* refactor: kubernetes, remove prefixes
* refactor: move the TargetGroup package to discovery/
* refactor: fix order of imports
2017-12-29 12:01:34 -08:00
|
|
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
2017-11-25 05:13:54 -08:00
|
|
|
"github.com/prometheus/prometheus/storage"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Appendable returns an Appender.
|
|
|
|
type Appendable interface {
|
|
|
|
Appender() (storage.Appender, error)
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewScrapeManager is the ScrapeManager constructor
|
2017-11-26 07:15:15 -08:00
|
|
|
func NewScrapeManager(logger log.Logger, app Appendable) *ScrapeManager {
|
2017-11-25 05:13:54 -08:00
|
|
|
|
|
|
|
return &ScrapeManager{
|
|
|
|
append: app,
|
|
|
|
logger: logger,
|
|
|
|
actionCh: make(chan func()),
|
|
|
|
scrapeConfigs: make(map[string]*config.ScrapeConfig),
|
|
|
|
scrapePools: make(map[string]*scrapePool),
|
2017-11-26 07:15:15 -08:00
|
|
|
graceShut: make(chan struct{}),
|
2017-11-25 05:13:54 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-12-01 04:59:24 -08:00
|
|
|
// ScrapeManager maintains a set of scrape pools and manages start/stop cycles
|
2017-11-25 05:13:54 -08:00
|
|
|
// when receiving new target groups form the discovery manager.
|
|
|
|
type ScrapeManager struct {
|
|
|
|
logger log.Logger
|
|
|
|
append Appendable
|
|
|
|
scrapeConfigs map[string]*config.ScrapeConfig
|
|
|
|
scrapePools map[string]*scrapePool
|
|
|
|
actionCh chan func()
|
2017-11-26 07:15:15 -08:00
|
|
|
graceShut chan struct{}
|
2017-11-25 05:13:54 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Run starts background processing to handle target updates and reload the scraping loops.
|
Refactor SD configuration to remove `config` dependency (#3629)
* refactor: move targetGroup struct and CheckOverflow() to their own package
* refactor: move auth and security related structs to a utility package, fix import error in utility package
* refactor: Azure SD, remove SD struct from config
* refactor: DNS SD, remove SD struct from config into dns package
* refactor: ec2 SD, move SD struct from config into the ec2 package
* refactor: file SD, move SD struct from config to file discovery package
* refactor: gce, move SD struct from config to gce discovery package
* refactor: move HTTPClientConfig and URL into util/config, fix import error in httputil
* refactor: consul, move SD struct from config into consul discovery package
* refactor: marathon, move SD struct from config into marathon discovery package
* refactor: triton, move SD struct from config to triton discovery package, fix test
* refactor: zookeeper, move SD structs from config to zookeeper discovery package
* refactor: openstack, remove SD struct from config, move into openstack discovery package
* refactor: kubernetes, move SD struct from config into kubernetes discovery package
* refactor: notifier, use targetgroup package instead of config
* refactor: tests for file, marathon, triton SD - use targetgroup package instead of config.TargetGroup
* refactor: retrieval, use targetgroup package instead of config.TargetGroup
* refactor: storage, use config util package
* refactor: discovery manager, use targetgroup package instead of config.TargetGroup
* refactor: use HTTPClient and TLS config from configUtil instead of config
* refactor: tests, use targetgroup package instead of config.TargetGroup
* refactor: fix tagetgroup.Group pointers that were removed by mistake
* refactor: openstack, kubernetes: drop prefixes
* refactor: remove import aliases forced due to vscode bug
* refactor: move main SD struct out of config into discovery/config
* refactor: rename configUtil to config_util
* refactor: rename yamlUtil to yaml_config
* refactor: kubernetes, remove prefixes
* refactor: move the TargetGroup package to discovery/
* refactor: fix order of imports
2017-12-29 12:01:34 -08:00
|
|
|
func (m *ScrapeManager) Run(tsets <-chan map[string][]*targetgroup.Group) error {
|
2017-11-25 05:13:54 -08:00
|
|
|
level.Info(m.logger).Log("msg", "Starting scrape manager...")
|
|
|
|
|
|
|
|
for {
|
|
|
|
select {
|
|
|
|
case f := <-m.actionCh:
|
|
|
|
f()
|
|
|
|
case ts := <-tsets:
|
2017-12-30 09:27:50 -08:00
|
|
|
m.reload(ts)
|
2017-11-26 07:15:15 -08:00
|
|
|
case <-m.graceShut:
|
|
|
|
return nil
|
2017-11-25 05:13:54 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-26 07:15:15 -08:00
|
|
|
// Stop cancels all running scrape pools and blocks until all have exited.
|
|
|
|
func (m *ScrapeManager) Stop() {
|
|
|
|
for _, sp := range m.scrapePools {
|
|
|
|
sp.stop()
|
|
|
|
}
|
|
|
|
close(m.graceShut)
|
|
|
|
}
|
|
|
|
|
2017-11-25 05:13:54 -08:00
|
|
|
// ApplyConfig resets the manager's target providers and job configurations as defined by the new cfg.
|
|
|
|
func (m *ScrapeManager) ApplyConfig(cfg *config.Config) error {
|
|
|
|
done := make(chan struct{})
|
|
|
|
m.actionCh <- func() {
|
2018-01-14 11:41:53 -08:00
|
|
|
c := make(map[string]*config.ScrapeConfig)
|
2017-11-25 05:13:54 -08:00
|
|
|
for _, scfg := range cfg.ScrapeConfigs {
|
2018-01-14 11:41:53 -08:00
|
|
|
c[scfg.JobName] = scfg
|
2017-11-25 05:13:54 -08:00
|
|
|
}
|
2018-01-14 11:41:53 -08:00
|
|
|
m.scrapeConfigs = c
|
2017-11-25 05:13:54 -08:00
|
|
|
close(done)
|
|
|
|
}
|
|
|
|
<-done
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// TargetMap returns map of active and dropped targets and their corresponding scrape config job name.
|
2017-12-18 11:41:31 -08:00
|
|
|
func (m *ScrapeManager) TargetMap() map[string][]*Target {
|
|
|
|
targetsMap := make(chan map[string][]*Target)
|
|
|
|
m.actionCh <- func() {
|
|
|
|
targets := make(map[string][]*Target)
|
|
|
|
for jobName, sp := range m.scrapePools {
|
|
|
|
sp.mtx.RLock()
|
|
|
|
for _, t := range sp.targets {
|
|
|
|
targets[jobName] = append(targets[jobName], t)
|
|
|
|
}
|
|
|
|
targets[jobName] = append(targets[jobName], sp.droppedTargets...)
|
|
|
|
sp.mtx.RUnlock()
|
2017-11-25 05:13:54 -08:00
|
|
|
}
|
2017-12-18 11:41:31 -08:00
|
|
|
targetsMap <- targets
|
2017-11-25 05:13:54 -08:00
|
|
|
}
|
2017-12-18 11:41:31 -08:00
|
|
|
return <-targetsMap
|
2017-11-25 05:13:54 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Targets returns the targets currently being scraped.
|
|
|
|
func (m *ScrapeManager) Targets() []*Target {
|
|
|
|
targets := make(chan []*Target)
|
|
|
|
m.actionCh <- func() {
|
|
|
|
var t []*Target
|
|
|
|
for _, p := range m.scrapePools {
|
|
|
|
p.mtx.RLock()
|
|
|
|
for _, tt := range p.targets {
|
|
|
|
t = append(t, tt)
|
|
|
|
}
|
|
|
|
p.mtx.RUnlock()
|
|
|
|
}
|
|
|
|
targets <- t
|
|
|
|
}
|
|
|
|
return <-targets
|
|
|
|
}
|
|
|
|
|
2017-12-30 09:27:50 -08:00
|
|
|
func (m *ScrapeManager) reload(t map[string][]*targetgroup.Group) {
|
2017-11-25 05:13:54 -08:00
|
|
|
for tsetName, tgroup := range t {
|
|
|
|
scrapeConfig, ok := m.scrapeConfigs[tsetName]
|
|
|
|
if !ok {
|
2017-12-30 09:27:50 -08:00
|
|
|
level.Error(m.logger).Log("msg", "error reloading target set", "err", fmt.Sprintf("invalid config id:%v", tsetName))
|
|
|
|
continue
|
2017-11-25 05:13:54 -08:00
|
|
|
}
|
|
|
|
|
2017-11-26 07:15:15 -08:00
|
|
|
// Scrape pool doesn't exist so start a new one.
|
2017-11-25 05:13:54 -08:00
|
|
|
existing, ok := m.scrapePools[tsetName]
|
|
|
|
if !ok {
|
2017-11-26 07:15:15 -08:00
|
|
|
sp := newScrapePool(scrapeConfig, m.append, log.With(m.logger, "scrape_pool", tsetName))
|
2017-11-25 05:13:54 -08:00
|
|
|
m.scrapePools[tsetName] = sp
|
|
|
|
sp.Sync(tgroup)
|
|
|
|
|
|
|
|
} else {
|
|
|
|
existing.Sync(tgroup)
|
|
|
|
}
|
2018-01-14 11:42:31 -08:00
|
|
|
}
|
2017-11-25 05:13:54 -08:00
|
|
|
|
2018-01-14 11:42:31 -08:00
|
|
|
// Cleanup - check the config and cancel the scrape loops if it don't exist in the scrape config.
|
|
|
|
for name, sp := range m.scrapePools {
|
|
|
|
if _, ok := m.scrapeConfigs[name]; !ok {
|
|
|
|
sp.stop()
|
|
|
|
delete(m.scrapePools, name)
|
2017-11-25 05:13:54 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|