Skip to content

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)で確認できます: OpenTelemetry-Prometheus