Metric Reporters

    Metrics can be exposed to an external system by configuring one or several reporters in . These reporters will be instantiated on each job and task manager when they are started.

    • metrics.reporter.<name>.<config>: Generic setting <config> for the reporter named <name>.
    • metrics.reporter.<name>.class: The reporter class to use for the reporter named <name>.
    • metrics.reporter.<name>.factory.class: The reporter factory class to use for the reporter named <name>.
    • metrics.reporter.<name>.interval: The reporter interval to use for the reporter named <name>.
    • metrics.reporter.<name>.scope.delimiter: The delimiter to use for the identifier (default value use metrics.scope.delimiter) for the reporter named <name>.
    • metrics.reporter.<name>.scope.variables.excludes: (optional) A semi-colon (;) separate list of variables that should be ignored by tag-based reporters (e.g., Prometheus, InfluxDB).
    • metrics.reporters: (optional) A comma-separated include list of reporter names. By default all configured reporters will be used.

    All reporters must at least have either the class or factory.class property. Which property may/should be used depends on the reporter implementation. See the individual reporter configuration sections for more information. Some reporters (referred to as Scheduled) allow specifying a reporting interval. Below more settings specific to each reporter will be listed.

    Example reporter configuration that specifies multiple reporters:

    Important: The jar containing the reporter must be accessible when Flink is started. Reporters that support the factory.class property can be loaded as plugins. Otherwise the jar must be placed in the /lib folder. Reporters that are shipped with Flink (i.e., all reporters documented on this page) are available by default.

    You can write your own Reporter by implementing the org.apache.flink.metrics.reporter.MetricReporter interface. If the Reporter should send out reports regularly you have to implement the Scheduled interface as well. By additionally implementing a MetricReporterFactory your reporter can also be loaded as a plugin.

    The following sections list the supported reporters.

    You don’t have to include an additional dependency since the JMX reporter is available by default but not activated.

    Parameters:

    Example configuration:

    1. metrics.reporter.jmx.factory.class: org.apache.flink.metrics.jmx.JMXReporterFactory
    2. metrics.reporter.jmx.port: 8789

    Metrics exposed through JMX are identified by a domain and a list of key-properties, which together form the object name.

    The domain always begins with org.apache.flink followed by a generalized metric identifier. In contrast to the usual identifier it is not affected by scope-formats, does not contain any variables and is constant across jobs. An example for such a domain would be .

    The domain thus identifies a metric class, while the key-property list identifies one (or multiple) instances of that metric.

    Graphite

    Parameters:

    • host - the Graphite server host
    • port - the Graphite server port
    • protocol - protocol to use (TCP/UDP)

    Example configuration:

    1. metrics.reporter.grph.factory.class: org.apache.flink.metrics.graphite.GraphiteReporterFactory
    2. metrics.reporter.grph.host: localhost
    3. metrics.reporter.grph.port: 2003
    4. metrics.reporter.grph.protocol: TCP
    5. metrics.reporter.grph.interval: 60 SECONDS

    In order to use this reporter you must copy /opt/flink-metrics-influxdb-1.14.4.jar into the plugins/influxdb folder of your Flink distribution.

    Parameters:

    Example configuration:

    The reporter would send metrics using http protocol to the InfluxDB server with the specified retention policy (or the default policy specified on the server). All Flink metrics variables (see ) are exported as InfluxDB tags.

    Prometheus

    Parameters:

    • port - (optional) the port the Prometheus exporter listens on, defaults to 9249. In order to be able to run several instances of the reporter on one host (e.g. when one TaskManager is colocated with the JobManager) it is advisable to use a port range like 9250-9260.
    • filterLabelValueCharacters - (optional) Specifies whether to filter label value characters. If enabled, all characters not matching [a-zA-Z0-9:_] will be removed, otherwise no characters will be removed. Before disabling this option please ensure that your label values meet the .

    Example configuration:

    1. metrics.reporter.prom.class: org.apache.flink.metrics.prometheus.PrometheusReporter

    All Flink metrics variables (see List of all Variables) are exported to Prometheus as labels.

    Parameters:

    Example configuration:

    1. metrics.reporter.promgateway.class: org.apache.flink.metrics.prometheus.PrometheusPushGatewayReporter
    2. metrics.reporter.promgateway.port: 9091
    3. metrics.reporter.promgateway.jobName: myJob
    4. metrics.reporter.promgateway.randomJobNameSuffix: true
    5. metrics.reporter.promgateway.deleteOnShutdown: false
    6. metrics.reporter.promgateway.groupingKey: k1=v1;k2=v2
    7. metrics.reporter.promgateway.interval: 60 SECONDS

    The PrometheusPushGatewayReporter pushes metrics to a Pushgateway, which can be scraped by Prometheus.

    Please see the for use-cases.

    StatsD

    Parameters:

    • host - the StatsD server host
    • port - the StatsD server port

    Example configuration:

    Note any variables in Flink metrics, such as , <job_name>, <tm_id>, <subtask_index>, <task_name>, and <operator_name>, will be sent to Datadog as tags. Tags will look like host:localhost and job_name:myjobname.

    Note Histograms are exposed as a series of gauges following the naming convention of Datadog histograms (<metric_name>.<aggregation>). The min aggregation is reported by default, whereas sum is not available. In contrast to Datadog-provided Histograms the reported aggregations are not computed for a specific reporting interval.

    Parameters:

    • apikey - the Datadog API key
    • tags - (optional) the global tags that will be applied to metrics when sending to Datadog. Tags should be separated by comma only
    • proxyHost - (optional) The proxy host to use when sending to Datadog.
    • proxyPort - (optional) The proxy port to use when sending to Datadog, defaults to 8080.
    • dataCenter - (optional) The data center (EU/US) to connect to, defaults to US.
    • maxMetricsPerRequest - (optional) The maximum number of metrics to include in each request, defaults to 2000.

    Example configuration:

    1. metrics.reporter.dghttp.factory.class: org.apache.flink.metrics.datadog.DatadogHttpReporterFactory
    2. metrics.reporter.dghttp.apikey: xxx
    3. metrics.reporter.dghttp.tags: myflinkapp,prod
    4. metrics.reporter.dghttp.proxyHost: my.web.proxy.com
    5. metrics.reporter.dghttp.proxyPort: 8080
    6. metrics.reporter.dghttp.dataCenter: US
    7. metrics.reporter.dghttp.maxMetricsPerRequest: 2000
    8. metrics.reporter.dghttp.interval: 60 SECONDS

    Slf4j

    1. metrics.reporter.slf4j.interval: 60 SECONDS