OpenTelemetryを統合してメトリクスを表示する
EMQXは、gRPC OTELプロトコルを介してメトリクスをOpenTelemetry Collectorに直接プッシュする機能を内蔵しています。Collectorは、その後データを任意のバックエンドにルーティング、フィルタリング、変換して保存および可視化が可能です。
このページでは、Dashboardを通じてEMQXとOpenTelemetryを統合し、PrometheusでEMQXのメトリクスを表示する方法を紹介します。
前提条件
OpenTelemetryとの統合を行う前に、OpenTelemetryとPrometheusをデプロイおよび設定する必要があります。
- OpenTelemetry Collectorをデプロイします。
- CollectorのgRPC受信ポート(デフォルトは4317)およびPrometheusメトリクスのエクスポートポート(8889)を設定します。
yaml
# otel-collector-config.yaml
receivers:
otlp:
protocols:
grpc:
exporters:
prometheus:
endpoint: "0.0.0.0:8889"
processors:
batch:
service:
pipelines:
metrics:
receivers: [otlp]
processors: [batch]
exporters: [prometheus]- Prometheusをデプロイします。
- Prometheusを設定し、Collectorが収集したメトリクスをスクレイプします。
yaml
# prometheus.yaml
scrape_configs:
- job_name: 'otel-collector'
scrape_interval: 10s
static_configs:
- targets: ['otel-collector:8889'] # EMQXメトリクス
- targets: ['otel-collector:8888'] # CollectorメトリクスEMQXでOpenTelemetryメトリクスを有効化する
EMQXのOpenTelemetryメトリクス機能との統合は、EMQX Dashboardまたは設定ファイルで行えます。EMQX Dashboardでは、左側のナビゲーションメニューから Management -> Monitoring をクリックし、Integration タブでメトリクスの設定を行います。
以下の設定をEMQXのcluster.hoconファイルに追加してください(EMQXがローカルで動作している場合の例です):
bash
opentelemetry {
exporter {
endpoint = "http://localhost:4317"
headers {
authorization = ""Basic dXNlcjpwYXNzd29yZA=="
}
}
metrics {
interval = "10s"
}
}PrometheusでEMQXメトリクスを可視化する
EMQXのメトリクスは、PrometheusのWebコンソール(http://otel-collector:9090)で確認できます: 