settings.go 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. package metrics
  2. import (
  3. "fmt"
  4. "strings"
  5. "time"
  6. "github.com/grafana/grafana/pkg/infra/metrics/graphitebridge"
  7. "github.com/grafana/grafana/pkg/setting"
  8. "github.com/prometheus/client_golang/prometheus"
  9. )
  10. func (im *InternalMetricsService) readSettings() error {
  11. var section, err = im.Cfg.Raw.GetSection("metrics")
  12. if err != nil {
  13. return fmt.Errorf("Unable to find metrics config section %v", err)
  14. }
  15. im.intervalSeconds = section.Key("interval_seconds").MustInt64(10)
  16. if err := im.parseGraphiteSettings(); err != nil {
  17. return fmt.Errorf("Unable to parse metrics graphite section, %v", err)
  18. }
  19. return nil
  20. }
  21. func (im *InternalMetricsService) parseGraphiteSettings() error {
  22. graphiteSection, err := im.Cfg.Raw.GetSection("metrics.graphite")
  23. if err != nil {
  24. return nil
  25. }
  26. address := graphiteSection.Key("address").String()
  27. if address == "" {
  28. return nil
  29. }
  30. bridgeCfg := &graphitebridge.Config{
  31. URL: address,
  32. Prefix: graphiteSection.Key("prefix").MustString("prod.grafana.%(instance_name)s"),
  33. CountersAsDelta: true,
  34. Gatherer: prometheus.DefaultGatherer,
  35. Interval: time.Duration(im.intervalSeconds) * time.Second,
  36. Timeout: 10 * time.Second,
  37. Logger: &logWrapper{logger: metricsLogger},
  38. ErrorHandling: graphitebridge.ContinueOnError,
  39. }
  40. safeInstanceName := strings.Replace(setting.InstanceName, ".", "_", -1)
  41. prefix := graphiteSection.Key("prefix").Value()
  42. if prefix == "" {
  43. prefix = "prod.grafana.%(instance_name)s."
  44. }
  45. bridgeCfg.Prefix = strings.Replace(prefix, "%(instance_name)s", safeInstanceName, -1)
  46. im.graphiteCfg = bridgeCfg
  47. return nil
  48. }