BYOC オブザーバビリティ
BYOC デプロイメントには包括的なオブザーバビリティ機能が含まれており、専用の Prometheus モニタリングスタックおよび ClickHouse サーバーからのメトリックエンドポイントを通じて ClickHouse サービスを監視できます。すべてのオブザーバビリティデータはクラウドアカウント内に保持されるため、モニタリング基盤を完全に制御できます。
Prometheus モニタリングのアプローチ
BYOC では、Prometheus を使用してメトリクスを収集および可視化する方法として、2 つの主なアプローチを提供しています。
- 組み込みの Prometheus スタックに接続する: BYOC Kubernetes クラスター内で動作する、集中管理された事前インストール済みの Prometheus インスタンスにアクセスします。
- ClickHouse のメトリクスを直接スクレイプする: 各 ClickHouse サービスによって公開されている
/metrics_allエンドポイントを、自前の Prometheus デプロイメントのスクレイプ対象として指定します。
監視方法の比較
| 機能 | 組み込み Prometheus スタック | ClickHouse サービスからの直接スクレイピング |
|---|---|---|
| メトリクスの範囲 | ClickHouse、Kubernetes、および補助サービスからのメトリクスを集約(クラスター全体の可視性) | 個々の ClickHouse サーバーからのメトリクスのみ |
| セットアップ手順 | プライベートロードバランサーなど、プライベートネットワークアクセスの設定が必要 | Prometheus を設定して、パブリックまたはプライベートの ClickHouse エンドポイントをスクレイプするだけ |
| 接続方法 | VPC/ネットワーク内のプライベートロードバランサー経由 | データベースアクセスに使用しているのと同じエンドポイント |
| 認証 | 不要(プライベートネットワークで制限) | ClickHouse サービスの認証情報を使用 |
| ネットワーク前提条件 | プライベートロードバランサーと適切なネットワーク接続 | ClickHouse エンドポイントへアクセスできる任意のネットワークから利用可能 |
| 最適な用途 | インフラおよびサービス全体を対象とした総合的な監視 | サービス単位に特化した監視および統合 |
| 統合方法 | 外部 Prometheus でフェデレーションを設定してクラスターのメトリクスを取り込む | ClickHouse のメトリクスエンドポイントを直接 Prometheus の設定に追加 |
推奨: ほとんどのユースケースでは、組み込み Prometheus スタックとの統合を推奨します。これは、ClickHouse サーバーメトリクスだけでなく、BYOC デプロイメント内のすべてのコンポーネント(ClickHouse サービス、Kubernetes クラスター、および補助サービス)から包括的なメトリクスを提供するためです。
組み込みの BYOC Prometheus スタック
ClickHouse BYOC は、Prometheus、Grafana、AlertManager に加え、長期メトリクス保存用にオプションで Thanos を含む、完全な Prometheus 監視スタックを Kubernetes クラスター内にデプロイします。このスタックは次のメトリクスを収集します:
- ClickHouse サーバーおよび ClickHouse Keeper
- Kubernetes クラスターおよびシステムコンポーネント
- 基盤となるインフラストラクチャのノード
Prometheus スタックへのアクセス
組み込みの Prometheus スタックに接続するには、次の手順を実行します。
- BYOC 環境向けのプライベートロードバランサーを有効化してもらうため、ClickHouse Support に連絡します。
- Prometheus エンドポイント URL を ClickHouse Support にリクエストします。
- 通常は VPC ピアリングやその他のプライベートネットワーク構成を用いて、Prometheus エンドポイントへのプライベートネットワーク経由での接続性を検証します。
Prometheus エンドポイントは次の形式になります。
Prometheus スタックの URL にはプライベートネットワーク接続を通じてのみアクセスでき、認証は不要です。アクセスは、VPC ピアリングやその他のプライベート接続オプション経由で BYOC VPC に到達可能なネットワークに限定されています。
監視ツールとの統合
BYOC Prometheus スタックは、監視エコシステム全体で次のように活用できます。
オプション 1: Prometheus API にクエリを実行する
- お使いの監視プラットフォームやカスタムダッシュボードから、Prometheus API エンドポイントへ直接アクセスします。
- PromQL クエリを使用して、必要なメトリクスを抽出・集約・可視化します。
- 独自のダッシュボードやアラートパイプラインを構築する場合に最適です。
Prometheus のクエリエンドポイント:
オプション 2: 独自の Prometheus へメトリクスをフェデレーションする
- 外部 Prometheus インスタンスを設定し、ClickHouse BYOC Prometheus スタックからメトリクスをフェデレーション(pull)できるようにします。
- これにより、複数の環境やクラスターからのメトリクス収集を統合し、集中管理できます。
- Prometheus フェデレーションの設定例:
ClickHouse サービスの Prometheus 連携
ClickHouse サービスは Prometheus 互換のメトリクス用エンドポイントを公開しており、自前の Prometheus インスタンスを使用して直接スクレイプできます。この方法では ClickHouse 固有のメトリクスは取得できますが、Kubernetes や関連サービスのメトリクスは含まれません。
メトリクスエンドポイントへのアクセス
メトリクスエンドポイントは、ClickHouse サービスエンドポイントの /metrics_all で公開されています。
サンプル応答:
認証
メトリクスエンドポイントには、ClickHouse の認証情報を使用した認証が必要です。default ユーザーを使用するか、メトリクスのスクレイピング専用に最小権限のユーザーを作成することを推奨します。
必要な権限:
- サービスに接続するための
REMOTE権限 - 関連する system テーブルに対する
SELECT権限
ユーザー設定例:
Prometheus の設定
Prometheus インスタンスを構成し、ClickHouse のメトリクス エンドポイントをスクレイプさせます。
次の値を置き換えます:
<service-subdomain>.<byoc-subdomain>.<region>.<provider>.byoc.clickhouse-byoc.com:8443を実際のサービスエンドポイントに置き換える<username>と<password>をスクレイピングに使用するユーザーの認証情報に置き換える
ClickHouse Mixin
あらかじめ用意されたダッシュボード一式を利用したいチーム向けに、ClickHouse は Prometheus 用の ClickHouse Mixin を提供しています。これは、ClickHouse クラスターの監視向けに特化して設計された、あらかじめ構成済みの Grafana ダッシュボードです。
Grafana のセットアップと ClickHouse Mix-in のインポート
Prometheus インスタンスが ClickHouse 監視スタックと統合できたら、次の手順に従って Grafana でメトリクスを可視化できます。
- Grafana に Prometheus をデータソースとして追加する
Grafana のサイドバーで「Data sources」に移動し、「Add data source」をクリックして「Prometheus」を選択します。Prometheus インスタンスの URL と、接続に必要な認証情報を入力します。



- ClickHouse ダッシュボードをインポートする
Grafana でダッシュボード画面に移動し、「Import」を選択します。ダッシュボードの JSON ファイルをアップロードするか、その内容を直接貼り付けることができます。JSON ファイルは ClickHouse Mix-in リポジトリから取得します。
ClickHouse Mix-in Dashboard JSON

- メトリクスを確認する
ダッシュボードをインポートし、Prometheus データソースで設定すると、ClickHouse Cloud サービスからのリアルタイムのメトリクスが表示されるはずです。
