mirror of
https://github.com/prometheus/prometheus.git
synced 2024-12-31 16:37:26 -08:00
Merge branch 'beorn7/storage3' into beorn7/storage4
This commit is contained in:
commit
eb9caf13be
|
@ -242,10 +242,12 @@ func parse(args []string) error {
|
||||||
if err := parsePrometheusURL(); err != nil {
|
if err := parsePrometheusURL(); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := parseInfluxdbURL(); err != nil {
|
if err := parseInfluxdbURL(); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
if err := validateAlertmanagerURL(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
cfg.remote.InfluxdbPassword = os.Getenv("INFLUXDB_PW")
|
cfg.remote.InfluxdbPassword = os.Getenv("INFLUXDB_PW")
|
||||||
|
|
||||||
|
@ -266,7 +268,7 @@ func parsePrometheusURL() error {
|
||||||
}
|
}
|
||||||
|
|
||||||
if ok := govalidator.IsURL(cfg.prometheusURL); !ok {
|
if ok := govalidator.IsURL(cfg.prometheusURL); !ok {
|
||||||
return fmt.Errorf("Invalid Prometheus URL: %s", cfg.prometheusURL)
|
return fmt.Errorf("invalid Prometheus URL: %s", cfg.prometheusURL)
|
||||||
}
|
}
|
||||||
|
|
||||||
promURL, err := url.Parse(cfg.prometheusURL)
|
promURL, err := url.Parse(cfg.prometheusURL)
|
||||||
|
@ -289,7 +291,7 @@ func parseInfluxdbURL() error {
|
||||||
}
|
}
|
||||||
|
|
||||||
if ok := govalidator.IsURL(cfg.influxdbURL); !ok {
|
if ok := govalidator.IsURL(cfg.influxdbURL); !ok {
|
||||||
return fmt.Errorf("Invalid InfluxDB URL: %s", cfg.influxdbURL)
|
return fmt.Errorf("invalid InfluxDB URL: %s", cfg.influxdbURL)
|
||||||
}
|
}
|
||||||
|
|
||||||
url, err := url.Parse(cfg.influxdbURL)
|
url, err := url.Parse(cfg.influxdbURL)
|
||||||
|
@ -301,6 +303,23 @@ func parseInfluxdbURL() error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func validateAlertmanagerURL() error {
|
||||||
|
if cfg.notifier.AlertmanagerURL == "" {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
if ok := govalidator.IsURL(cfg.notifier.AlertmanagerURL); !ok {
|
||||||
|
return fmt.Errorf("invalid Alertmanager URL: %s", cfg.notifier.AlertmanagerURL)
|
||||||
|
}
|
||||||
|
url, err := url.Parse(cfg.notifier.AlertmanagerURL)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if url.Scheme == "" {
|
||||||
|
return fmt.Errorf("missing scheme in Alertmanager URL: %s", cfg.notifier.AlertmanagerURL)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
var helpTmpl = `
|
var helpTmpl = `
|
||||||
usage: prometheus [<args>]
|
usage: prometheus [<args>]
|
||||||
{{ range $cat, $flags := . }}{{ if ne $cat "." }} == {{ $cat | upper }} =={{ end }}
|
{{ range $cat, $flags := . }}{{ if ne $cat "." }} == {{ $cat | upper }} =={{ end }}
|
||||||
|
|
|
@ -48,6 +48,18 @@ func TestParse(t *testing.T) {
|
||||||
input: []string{"-storage.remote.influxdb-url", "'https://some-url/'"},
|
input: []string{"-storage.remote.influxdb-url", "'https://some-url/'"},
|
||||||
valid: false,
|
valid: false,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
input: []string{"-alertmanager.url", ""},
|
||||||
|
valid: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
input: []string{"-alertmanager.url", "http://alertmanager.company.com"},
|
||||||
|
valid: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
input: []string{"-alertmanager.url", "alertmanager.company.com"},
|
||||||
|
valid: false,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for i, test := range tests {
|
for i, test := range tests {
|
||||||
|
|
|
@ -15,6 +15,7 @@ package retrieval
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"sort"
|
||||||
"strings"
|
"strings"
|
||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
@ -134,11 +135,11 @@ func (tm *TargetManager) reload() {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Pools returns the targets currently being scraped bucketed by their job name.
|
// Pools returns the targets currently being scraped bucketed by their job name.
|
||||||
func (tm *TargetManager) Pools() map[string][]*Target {
|
func (tm *TargetManager) Pools() map[string]Targets {
|
||||||
tm.mtx.RLock()
|
tm.mtx.RLock()
|
||||||
defer tm.mtx.RUnlock()
|
defer tm.mtx.RUnlock()
|
||||||
|
|
||||||
pools := map[string][]*Target{}
|
pools := map[string]Targets{}
|
||||||
|
|
||||||
// TODO(fabxc): this is just a hack to maintain compatibility for now.
|
// TODO(fabxc): this is just a hack to maintain compatibility for now.
|
||||||
for _, ps := range tm.targetSets {
|
for _, ps := range tm.targetSets {
|
||||||
|
@ -151,6 +152,9 @@ func (tm *TargetManager) Pools() map[string][]*Target {
|
||||||
|
|
||||||
ps.scrapePool.mtx.RUnlock()
|
ps.scrapePool.mtx.RUnlock()
|
||||||
}
|
}
|
||||||
|
for _, targets := range pools {
|
||||||
|
sort.Sort(targets)
|
||||||
|
}
|
||||||
return pools
|
return pools
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -274,28 +278,28 @@ func (ts *targetSet) runProviders(ctx context.Context, providers map[string]Targ
|
||||||
updates := make(chan []*config.TargetGroup)
|
updates := make(chan []*config.TargetGroup)
|
||||||
|
|
||||||
go func(name string, prov TargetProvider) {
|
go func(name string, prov TargetProvider) {
|
||||||
var initial []*config.TargetGroup
|
|
||||||
|
|
||||||
select {
|
select {
|
||||||
case <-ctx.Done():
|
case <-ctx.Done():
|
||||||
wg.Done()
|
case initial, ok := <-updates:
|
||||||
return
|
// Handle the case that a target provider exits and closes the channel
|
||||||
case initial = <-updates:
|
// before the context is done.
|
||||||
|
if !ok {
|
||||||
|
break
|
||||||
|
}
|
||||||
// First set of all targets the provider knows.
|
// First set of all targets the provider knows.
|
||||||
|
for _, tgroup := range initial {
|
||||||
|
targets, err := targetsFromGroup(tgroup, ts.config)
|
||||||
|
if err != nil {
|
||||||
|
log.With("target_group", tgroup).Errorf("Target update failed: %s", err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
ts.tgroups[name+"/"+tgroup.Source] = targets
|
||||||
|
}
|
||||||
case <-time.After(5 * time.Second):
|
case <-time.After(5 * time.Second):
|
||||||
// Initial set didn't arrive. Act as if it was empty
|
// Initial set didn't arrive. Act as if it was empty
|
||||||
// and wait for updates later on.
|
// and wait for updates later on.
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, tgroup := range initial {
|
|
||||||
targets, err := targetsFromGroup(tgroup, ts.config)
|
|
||||||
if err != nil {
|
|
||||||
log.With("target_group", tgroup).Errorf("Target update failed: %s", err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
ts.tgroups[name+"/"+tgroup.Source] = targets
|
|
||||||
}
|
|
||||||
|
|
||||||
wg.Done()
|
wg.Done()
|
||||||
|
|
||||||
// Start listening for further updates.
|
// Start listening for further updates.
|
||||||
|
@ -303,7 +307,12 @@ func (ts *targetSet) runProviders(ctx context.Context, providers map[string]Targ
|
||||||
select {
|
select {
|
||||||
case <-ctx.Done():
|
case <-ctx.Done():
|
||||||
return
|
return
|
||||||
case tgs := <-updates:
|
case tgs, ok := <-updates:
|
||||||
|
// Handle the case that a target provider exits and closes the channel
|
||||||
|
// before the context is done.
|
||||||
|
if !ok {
|
||||||
|
return
|
||||||
|
}
|
||||||
for _, tg := range tgs {
|
for _, tg := range tgs {
|
||||||
if err := ts.update(name, tg); err != nil {
|
if err := ts.update(name, tg); err != nil {
|
||||||
log.With("target_group", tg).Errorf("Target update failed: %s", err)
|
log.With("target_group", tg).Errorf("Target update failed: %s", err)
|
||||||
|
|
|
@ -21,7 +21,7 @@ version=$( cat version/VERSION )
|
||||||
revision=$( git rev-parse --short HEAD 2> /dev/null || echo 'unknown' )
|
revision=$( git rev-parse --short HEAD 2> /dev/null || echo 'unknown' )
|
||||||
branch=$( git rev-parse --abbrev-ref HEAD 2> /dev/null || echo 'unknown' )
|
branch=$( git rev-parse --abbrev-ref HEAD 2> /dev/null || echo 'unknown' )
|
||||||
host=$( hostname )
|
host=$( hostname )
|
||||||
build_date=$( date +%Y%m%d-%H:%M:%S )
|
build_date=$( TZ=UTC date +%Y%m%d-%H:%M:%S )
|
||||||
go_version=$( go version | sed -e 's/^[^0-9.]*\([0-9.]*\).*/\1/' )
|
go_version=$( go version | sed -e 's/^[^0-9.]*\([0-9.]*\).*/\1/' )
|
||||||
|
|
||||||
if [ "$(go env GOOS)" = "windows" ]; then
|
if [ "$(go env GOOS)" = "windows" ]; then
|
||||||
|
|
|
@ -92,7 +92,7 @@ type PrometheusStatus struct {
|
||||||
|
|
||||||
// A function that returns the current scrape targets pooled
|
// A function that returns the current scrape targets pooled
|
||||||
// by their job name.
|
// by their job name.
|
||||||
TargetPools func() map[string][]*retrieval.Target
|
TargetPools func() map[string]retrieval.Targets
|
||||||
// A function that returns all loaded rules.
|
// A function that returns all loaded rules.
|
||||||
Rules func() []rules.Rule
|
Rules func() []rules.Rule
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue