mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-01 16:50:24 +01:00
be6da5053f
- Return meta-labels for the discovered targets via promutils.Labels instead of map[string]string. This improves the speed of generating meta-labels for discovered targets by up to 5x. - Remove memory allocations in hot paths during ScrapeWork generation. The ScrapeWork contains scrape settings for a single discovered target. This improves the service discovery speed by up to 2x.
60 lines
2.3 KiB
Go
60 lines
2.3 KiB
Go
package consul
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/VictoriaMetrics/VictoriaMetrics/lib/promauth"
|
|
"github.com/VictoriaMetrics/VictoriaMetrics/lib/promutils"
|
|
"github.com/VictoriaMetrics/VictoriaMetrics/lib/proxy"
|
|
)
|
|
|
|
// SDConfig represents service discovery config for Consul.
|
|
//
|
|
// See https://prometheus.io/docs/prometheus/latest/configuration/configuration/#consul_sd_config
|
|
type SDConfig struct {
|
|
Server string `yaml:"server,omitempty"`
|
|
Token *promauth.Secret `yaml:"token"`
|
|
Datacenter string `yaml:"datacenter"`
|
|
|
|
// Namespace only supported at enterprise consul.
|
|
// https://www.consul.io/docs/enterprise/namespaces
|
|
Namespace string `yaml:"namespace,omitempty"`
|
|
// Partition only supported at enteprise consul.
|
|
// https://developer.hashicorp.com/consul/docs/enterprise/admin-partitions
|
|
Partition string `yaml:"partition,omitempty"`
|
|
|
|
Scheme string `yaml:"scheme,omitempty"`
|
|
Username string `yaml:"username"`
|
|
Password *promauth.Secret `yaml:"password"`
|
|
HTTPClientConfig promauth.HTTPClientConfig `yaml:",inline"`
|
|
ProxyURL *proxy.URL `yaml:"proxy_url,omitempty"`
|
|
ProxyClientConfig promauth.ProxyClientConfig `yaml:",inline"`
|
|
Services []string `yaml:"services,omitempty"`
|
|
Tags []string `yaml:"tags,omitempty"`
|
|
NodeMeta map[string]string `yaml:"node_meta,omitempty"`
|
|
TagSeparator *string `yaml:"tag_separator,omitempty"`
|
|
AllowStale *bool `yaml:"allow_stale,omitempty"`
|
|
// RefreshInterval time.Duration `yaml:"refresh_interval"`
|
|
// refresh_interval is obtained from `-promscrape.consulSDCheckInterval` command-line option.
|
|
}
|
|
|
|
// GetLabels returns Consul labels according to sdc.
|
|
func (sdc *SDConfig) GetLabels(baseDir string) ([]*promutils.Labels, error) {
|
|
cfg, err := getAPIConfig(sdc, baseDir)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("cannot get API config: %w", err)
|
|
}
|
|
ms := getServiceNodesLabels(cfg)
|
|
return ms, nil
|
|
}
|
|
|
|
// MustStop stops further usage for sdc.
|
|
func (sdc *SDConfig) MustStop() {
|
|
v := configMap.Delete(sdc)
|
|
if v != nil {
|
|
// v can be nil if GetLabels wasn't called yet.
|
|
cfg := v.(*apiConfig)
|
|
cfg.mustStop()
|
|
}
|
|
}
|