Exporting Metrics (Surfacers)
One of the biggest strengths of cloudprober is that it can export data to multiple monitoring systems, even simultaneously, just based on simple configuration. Cloudprober does that using a built-in mechanism, called surfacers. Each surfacer type implements interface for a specific monitoring system, for example, cloudwatch surfacer publishes data to AWS Cloudwatch. You can configure multiple surfacers at the same time. If you don’t specify any surfacer, prometheus and file surfacers are enabled automatically.
Cloudprober currently supports following surfacer types:
- Prometheus (config)
- OpenTelemetry (OTEL) (config) [New in v0.13.2]
- Stackdriver (Google Cloud Monitoring)
- Google Pub/Sub (config)
- Postgres (config)
- File (config)
- Cloudwatch (AWS Cloud Monitoring)
Overall surfacers config.
It’s easy to add more surfacers without having to understand the internals of cloudprober. You only need to implement the Surfacer interface.
Configuration
Adding surfacers to cloudprober is as easy as adding “surfacer” config stanzas to your config, like the following:
# Enable prometheus and stackdriver surfacers.
# Make probe metrics available at the URL :<cloudprober_port>/metrics, for
# scraping by prometheus.
surfacer {
  type: PROMETHEUS
  prometheus_surfacer {
    # Following option adds a prefix to exported metrics, for example,
    # "total" metric is exported as "cloudprober_total".
    metrics_prefix: "cloudprober_"
  }
}
# Stackdriver (Google Cloud Monitoring) surfacer_ No other configuration
# is necessary if running on GCP.
surfacer {
  type: STACKDRIVER
}
Filtering Metrics
You can control which metrics are published to a surfacer using the filtering mechanisms. For example, you may want to publish only specific metrics to AWS Cloudwatch to save on the costs.
Filtering by Label
To filter metrics by labels, use one of the following options in the surfacers config:
- allow_metrics_with_label(- allowMetricsWithLabelin yaml)
- ignore_metrics_with_label(- ignoreMetricsWithLabelin yaml)
Note: ignore_metrics_with_label takes precedence over
allow_metrics_with_label.
For example, to ignore all sysvar metrics:
surfacer {
  type: PROMETHEUS
  ignore_metrics_with_label {
    key: "probe",
    value: "sysvars",
  }
}
Or to only allow metrics from http probes:
surfacer {
  type: PROMETHEUS
  allow_metrics_with_label {
    key: "ptype",
    value: "http",
  }
}
Filtering by Metric Name
To filter metrics by name, use one of the following options in the surfacers config:
- allow_metrics_with_name(- allowMetricsWithNamein yaml)
- ignore_metrics_with_name(- ignoreMetricsWithNamein yaml)
Note: ignore_metrics_with_name takes precedence over
allow_metrics_with_name.
To filter out all validation_failure metrics by name:
surfacer {
  type: PROMETHEUS
  ignore_metrics_with_name: "validation_failure"
}
Modifying Metrics
You can configure surfacers to modify the metrics before they are sent to the backend monitoring system:
- add_failure_metric: Export failure count along with the default total and success metrics: - surfacer { type: ... add_failure_metric: true .. }- NOTE: This option is now enabled by default for all surfacers, except for FILE and PUBSUB surfacers. 
- export_as_gauge: Export gauge metrics instead of cumulative. Cloudprober exports cumulative metrics (sum of values so far) by default, but you can configure it to export gauge metrics instead. Gauge metrics make point-in-time calculations easier (e.g. you can just divide latency by success to get the average latency), but we lose the historical information if metrics are not received for a few intervals for some reason. - surfacer { type: ... export_as_gauge: true .. }
Additional labels
See additional labels for how you can add additional labels to cloudprober metrics.
Adding your own metrics
For external probes, Cloudprober also allows external programs to provide additional metrics. See External Probe for more details.