mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-02-09 15:27:11 +00:00
lib/promscrape: add -promscrape.config.dryRun
flag for checking -promscrape.config
for errors or unsupported options
Updates https://github.com/VictoriaMetrics/VictoriaMetrics/issues/508 Updates https://github.com/VictoriaMetrics/VictoriaMetrics/issues/362
This commit is contained in:
parent
901093279e
commit
482bae8466
1 changed files with 12 additions and 1 deletions
|
@ -5,6 +5,7 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"net/url"
|
"net/url"
|
||||||
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"strings"
|
"strings"
|
||||||
"sync/atomic"
|
"sync/atomic"
|
||||||
|
@ -25,6 +26,9 @@ import (
|
||||||
var (
|
var (
|
||||||
strictParse = flag.Bool("promscrape.config.strictParse", false, "Whether to allow only supported fields in '-promscrape.config'. "+
|
strictParse = flag.Bool("promscrape.config.strictParse", false, "Whether to allow only supported fields in '-promscrape.config'. "+
|
||||||
"This option may be used for errors detection in '-promscrape.config' file")
|
"This option may be used for errors detection in '-promscrape.config' file")
|
||||||
|
dryRun = flag.Bool("promscrape.config.dryRun", false, "Checks -promscrape.config file for errors and unsupported fields and then exits. "+
|
||||||
|
"Returns non-zero exit code on parsing errors and emits these errors to stderr. "+
|
||||||
|
"Pass -loggerLevel=ERROR if you don't need to see info messages in the output")
|
||||||
)
|
)
|
||||||
|
|
||||||
// Config represents essential parts from Prometheus config defined at https://prometheus.io/docs/prometheus/latest/configuration/configuration/
|
// Config represents essential parts from Prometheus config defined at https://prometheus.io/docs/prometheus/latest/configuration/configuration/
|
||||||
|
@ -114,6 +118,13 @@ func loadConfig(path string) (cfg *Config, data []byte, err error) {
|
||||||
if err := cfgObj.parse(data, path); err != nil {
|
if err := cfgObj.parse(data, path); err != nil {
|
||||||
return nil, nil, fmt.Errorf("cannot parse Prometheus config from %q: %s", path, err)
|
return nil, nil, fmt.Errorf("cannot parse Prometheus config from %q: %s", path, err)
|
||||||
}
|
}
|
||||||
|
if *dryRun {
|
||||||
|
// This is a dirty hack for checking Prometheus config only.
|
||||||
|
// See https://github.com/VictoriaMetrics/VictoriaMetrics/issues/362
|
||||||
|
// and https://github.com/VictoriaMetrics/VictoriaMetrics/issues/508 for details.
|
||||||
|
logger.Infof("Success: the config at %q has no errors; exitting with 0 status code", path)
|
||||||
|
os.Exit(0)
|
||||||
|
}
|
||||||
return &cfgObj, data, nil
|
return &cfgObj, data, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -139,7 +150,7 @@ func (cfg *Config) parse(data []byte, path string) error {
|
||||||
|
|
||||||
func unmarshalMaybeStrict(data []byte, dst interface{}) error {
|
func unmarshalMaybeStrict(data []byte, dst interface{}) error {
|
||||||
var err error
|
var err error
|
||||||
if *strictParse {
|
if *strictParse || *dryRun {
|
||||||
err = yaml.UnmarshalStrict(data, dst)
|
err = yaml.UnmarshalStrict(data, dst)
|
||||||
} else {
|
} else {
|
||||||
err = yaml.Unmarshal(data, dst)
|
err = yaml.Unmarshal(data, dst)
|
||||||
|
|
Loading…
Reference in a new issue