The OpenTelemetry Collector, when configured with a Prometheus receiver, provides an integration with ClickHouse to scrape Prometheus metrics. The Collector uses the Prometheus Receiver to fetch metrics from the configured path in the ClickHouse configuration file. From there, the metrics are processed and exported to Cloud Observability.
To complete the integration you will:
You need to configure ClickHouse to use the Prometheus exporter.
In the ClickHouse server config.xml
configuration file, add the following:
1
2
3
4
5
6
7
<prometheus>
<endpoint>/metrics</endpoint>
<port>8001</port>
<metrics>true</metrics>
<events>true</events>
<asynchronous_metrics>true</asynchronous_metrics>
</prometheus>
For more details about using ClickHouse with the Prometheus exporter, see the official ClickHouse documentation.
In the Collector configuration file, configure the Prometheus receiver to use the ClickHouse Prometheus endpoint as a scrape target.
1
2
3
4
5
6
7
8
9
10
receivers:
prometheus:
config:
scrape_configs:
- job_name: 'clickhouse-server'
metrics_path: '/v1/agent/metrics'
params:
format: ['prometheus']
static_configs:
- targets: ['${CLICKHOUSE_SERVER_HOST}']
The OpenTelemetry repo’s README provides additional details about Prometheus receiver configuration.
Once the ClickHouse receiver is configured, enable it by adding it to one or more pipelines as described in the Collector configuration documentation.
You can validate that metrics are reporting to Cloud Observability on the Metrics details page in Settings.
In Cloud Observability, click Settings > Metric details.
Search for ClickHouse metric names.
See the metric_log, asynchronous_metrics, and metrics Clickhouse documentation for a complete list of emitted metrics.
If needed, click on the metric to edit the description and how the units are displayed in Cloud Observability.
Use the Cloud Observability Terraform Provider to create a dashboard for the metrics.
For a more complete example that’s ready to run, see the ClickHouse integration in Cloud Observability OpenTelemetry Examples.
Updated Dec 1, 2022