Skip to content

Graphite Exporter


The Graphite collector can receive metrics data in Graphite plaintext protocol format, transform it, and make it available for use by systems like Prometheus. By configuring the appropriate Exporter address, you can integrate the metrics data into these systems.

Configuration

Preconditions

Collector Configuration

Go to the conf.d/graphite directory under the DataKit installation directory, copy graphite.conf.sample and name it graphite.conf. Examples are as follows:

[[inputs.graphite]]
  ## Address to open UDP/TCP, default 9109
  address = ":9109"

  # Whether to open StrictMatch
  # strict_match = false

  ## Example Mapping Configuration
  #[inputs.graphite.metric_mapper]
  # name = "test"
  # [[inputs.graphite.metric_mapper.mappings]]
  # match = "test.dispatcher.*.*.*"
  # name = "dispatcher_events_total"
  # measurement_name = "dispatcher_test"

  # [inputs.graphite.metric_mapper.mappings.labels]
  # action = "$2"
  # job = "test_dispatcher"
  # outcome = "$3"
  # processor = "$1"

  # [[inputs.graphite.metric_mapper.mappings]]
  # match = "*.signup.*.*"
  # name = "signup_events_total"
  # measurement_name = "signup_set"

  # [inputs.graphite.metric_mapper.mappings.labels]
  # job = "${1}_server"
  # outcome = "$3"
  # provider = "$2"

  # Regex Mapping Example
  # [[inputs.graphite.metric_mapper.mappings]]
  # match = '''servers\.(.*)\.networking\.subnetworks\.transmissions\.([a-z0-9-]+)\.(.*)'''
  # match_type = "regex"
  # name = "servers_networking_transmissions_${3}"
  # measurement_name = "servers_networking"

  # [inputs.graphite.metric_mapper.mappings.labels]
  # hostname = "${1}"
  # device = "${2}"

After configuration, restart DataKit.

Metric Mapping Configuration

Graphite collector can be configured to translate specific dot-separated graphite metrics into labeled metrics via configuration file. The conversion rules for these metrics are similar to the rules in statsd_exporter, but here they are configured in TOML format.

Metrics that don't match any mapping in the configuration file are translated into metrics without any labels and with names in which every non-alphanumeric character except _ and : is replaced with _. When configuring here, you need to specify the name of the metric set measurement_name, and the mapped metrics will be categorized under this metric set. If the metric set name is not specified or no mapping rules are configured, it will default to the graphite metric set.

An example mapping configuration:

[inputs.graphite.metric_mapper]
name = "test"
[[inputs.graphite.metric_mapper.mappings]]
match = "test.dispatcher.*.*.*"
name = "dispatcher_events_total"
measurement_name = "dispatcher_test"

[inputs.graphite.metric_mapper.mappings.labels]
action = "$2"
job = "test_dispatcher"
outcome = "$3"
processor = "$1"

[[inputs.graphite.metric_mapper.mappings]]
match = "*.signup.*.*"
name = "signup_events_total"
measurement_name = "signup_set"

[inputs.graphite.metric_mapper.mappings.labels]
job = "${1}_server"
outcome = "$3"
provider = "$2"

[[inputs.graphite_metric_mapper.mappings]]
match = "servers\\.(.*)\\.networking\\.subnetworks\\.transmissions\\.([a-z0-9-]+)\\.(.*)"
match_type = "regex"
name = "servers_networking_transmissions_${3}"
measurement_name = "servers_networking"

[inputs.graphite.metric_mapper.mappings.labels]
hostname = "${1}"
device = "${2}"

This would transform these example graphite metrics into metrics as follows:

test.dispatcher.FooProcessor.send.success
  => dispatcher_events_total{processor="FooProcessor", action="send", outcome="success", job="test_dispatcher"}

foo_product.signup.facebook.failure
  => signup_events_total{provider="facebook", outcome="failure", job="foo_product_server"}

test.web-server.foo.bar
  => test_web__server_foo_bar{}

servers.rack-003-server-c4de.networking.subnetworks.transmissions.eth0.failure.mean_rate
  => servers_networking_transmissions_failure_mean_rate{device="eth0",hostname="rack-003-server-c4de"}

Support Mapping Configuration

Glob Mapping

The default glob mapping style uses * to denote parts of the metric name that may vary.

Noted: now we use dot-separated, like test.a.b.c.d

An example mapping configuration:

[inputs.graphite.metric_mapper]
name = "test"
[[inputs.graphite.metric_mapper.mappings]]
match = "test.dispatcher.*.*.*"
name = "dispatcher_events_total"

[inputs.graphite.metric_mapper.mappings.labels]
action = "$2"
job = "test_dispatcher"
outcome = "$3"
processor = "$1"

[[inputs.graphite.metric_mapper.mappings]]
match = "*.signup.*.*"
name = "signup_events_total"

[inputs.graphite.metric_mapper.mappings.labels]
job = "${1}_server"
outcome = "$3"
provider = "$2"

This would transform these example metrics into metrics as follows:

test.dispatcher.FooProcessor.send.success
 => dispatcher_events_total{processor="FooProcessor", action="send", outcome="success", job="test_dispatcher"}

foo_product.signup.facebook.failure
 => signup_events_total{provider="facebook", outcome="failure", job="foo_product_server"}

test.web-server.foo.bar
 => test_web_server_foo_bar{}

Noted: Every mapping configuration must have name field, The metric's name can contain $n-style references to be replaced by the n-th wildcard match in the matching line. That allows for dynamic rewrites, such as:

[[inputs.graphite.metric_mapper.mappings]]
match = "test.*.*.counter"
name = "${2}_total"
measurement_name = "test_counter"

[inputs.graphite.metric_mapper.mappings.labels]
provider = "$1"

Here use test.a.b.c.counter as an example, $1 corresponds to a, $2corresponds to b, and so on.

Regular expression matching

The regex matching rules use standard regular expression matching to match metric names. You need to specify match_type = regex.

Noted: regex matching is slower than glob matching

An example mapping configuration:

[[inputs.graphite_metric_mapper.mappings]]
match = "servers\.(.*)\.networking\.subnetworks\.transmissions\.([a-z0-9-]+)\.(.*)"
match_type = "regex"
name = "servers_networking_transmissions_${3}"
measurement_name = "servers_networking"

[inputs.graphite.metric_mapper.mappings.labels]
hostname = "${1}"
device = "${2}"

Noted: In TOML, backslashes (\) need to be escaped when used in strings, so you need to double-escape the backslashes by \\

More details

please refer to statsd_exporter

StrictMatch

If you have a very large set of metrics you may want to skip the ones that don't match the mapping configuration. If that is the case you can force this behavior using the strict_match, and it will only store those metrics you really want.

[inputs.graphite.metric_mapper]
strict_match = true

Feedback

Is this page helpful? ×