メインコンテンツまでスキップ
メインコンテンツまでスキップ

ClickHouse Cloud とオブジェクトストレージの統合

オブジェクトストレージ ClickPipes は、Amazon S3 と Google Cloud Storage から ClickHouse Cloud へのデータを簡単かつ堅牢に取り込む方法を提供します。一時的な取り込みと継続的な取り込みの両方がサポートされており、正確に一度のみのセマンティクスが保証されます。

前提条件

ClickPipes の紹介に目を通しておいてください。

最初の ClickPipe を作成します

  1. クラウドコンソールで、左側のメニューから Data Sources ボタンを選択し、「ClickPipe を設定」をクリックします。
インポートの選択
  1. データソースを選択します。
データソースの種類を選択
  1. ClickPipe に名前、説明(オプション)、IAM ロールまたは資格情報、バケット URL を提供してフォームに記入します。bash ライクなワイルドカードを使用して複数のファイルを指定できます。詳細については、パスでのワイルドカード使用に関するドキュメンテーションを参照してください
接続詳細の入力
  1. UI には指定したバケット内のファイルのリストが表示されます。データ形式を選択します(現在、ClickHouse 形式のサブセットをサポートしています)し、継続的な取り込みを有効にするかどうかを選択します。詳細はこちら
データ形式とトピックの設定
  1. 次のステップでは、データを新しい ClickHouse テーブルに取り込むか、既存のテーブルを再利用するかを選択できます。画面の指示に従って、テーブル名、スキーマ、および設定を変更します。サンプルテーブルの上部で変更内容のリアルタイムプレビューを確認できます。
テーブル、スキーマ、および設定の設定

提供されたコントロールを使用して、詳細設定をカスタマイズすることもできます。

詳細設定の設定
  1. または、既存の ClickHouse テーブルにデータを取り込むこともできます。その場合、UI は、ソースのフィールドを選択した宛先テーブルの ClickHouse フィールドにマッピングできるようにします。
既存のテーブルを使用
参考

_path_size など、仮想カラムをフィールドにマッピングすることもできます。

  1. 最後に、内部 ClickPipes ユーザーの権限を設定できます。

権限: ClickPipes は、宛先テーブルにデータを書き込むための専用ユーザーを作成します。この内部ユーザーには、カスタムロールまたは次のいずれかの事前定義されたロールからロールを選択できます:

  • フルアクセス: クラスターへのフルアクセス。宛先テーブルで Materialized View または Dictionary を使用する場合に必要です。
  • 宛先テーブルのみ: 宛先テーブルに対する INSERT 権限のみ。
権限
  1. 「セットアップの完了」をクリックすることで、システムは ClickPipe を登録し、要約テーブルに表示されるようになります。
成功通知 削除通知

要約テーブルには、ClickHouse のソースまたは宛先テーブルのサンプルデータを表示するためのコントロールが提供されます。

宛先の表示

また、ClickPipe を削除するためのコントロールや取り込みジョブの概要を表示するためのコントロールもあります。

概要の表示
  1. おめでとうございます! 最初の ClickPipe の設定が完了しました。これがストリーミング ClickPipe である場合、リモートデータソースからのデータをリアルタイムに継続的に取り込むことになります。それ以外の場合は、バッチを取り込み、完了します。

サポートされているデータソース

名称ロゴ类型ステータス説明
Amazon S3オブジェクトストレージ安定オブジェクトストレージから大量のデータを取り込むために ClickPipes を構成します。
Google Cloud Storageオブジェクトストレージ安定オブジェクトストレージから大量のデータを取り込むために ClickPipes を構成します。

より多くのコネクタが ClickPipes に追加される予定です。詳しくは、お問い合わせください にアクセスしてください。

サポートされているデータ形式

サポートされている形式は以下の通りです:

正確に一度のみのセマンティクス

大規模データセットの取り込み中にさまざまな失敗が発生する可能性があり、これにより部分的な挿入や重複データが発生することがあります。オブジェクトストレージ ClickPipes は、挿入失敗に対して堅牢で、正確に一度のみのセマンティクスを提供します。これは、一時的な「ステージング」テーブルを使用することで実現されます。データは最初にステージングテーブルに挿入されます。この挿入に何らかの問題が発生した場合、ステージングテーブルをトランクすることができ、クリーンな状態から挿入を再試行できます。挿入が完了し、成功した場合にのみ、ステージングテーブルのパーティションがターゲットテーブルに移動されます。この戦略の詳細については、こちらのブログ投稿をご覧ください。

ビューサポート

ターゲットテーブル上でのマテリアライズドビューもサポートされています。ClickPipes は、ターゲットテーブルだけでなく、依存するマテリアライズドビューのためにもステージングテーブルを作成します。

非マテリアライズドビュー用のステージングテーブルは作成しません。つまり、ターゲットテーブルに 1 つ以上の下流のマテリアライズドビューがある場合、これらのマテリアライズドビューはターゲットテーブルからのビューを介してデータを選択しないようにしてください。そうしないと、マテリアライズドビュー内のデータが欠落する可能性があります。

スケーリング

オブジェクトストレージ ClickPipes のスケーリングは、構成された垂直オートスケーリング設定 によって決定される最小 ClickHouse サービスサイズに基づいて行われます。ClickPipe のサイズは、パイプが作成されたときに決定されます。ClickHouse サービス設定の後続の変更は、ClickPipe サイズに影響を及ぼしません。

大規模な取り込みジョブでスループットを増加させるには、ClickPipe を作成する前に ClickHouse サービスをスケールアップすることをお勧めします。

制限事項

  • 宛先テーブル、マテリアライズドビュー(カスケードマテリアライズドビューを含む)、またはマテリアライズドビューのターゲットテーブルに対する変更は、自動的にパイプによって反映されず、エラーを引き起こす可能性があります。パイプを停止し、必要な変更を加えた後、エラーや重複データの発生を避けるためにパイプを再起動する必要があります。
  • サポートされているビュ―の種類には制限があります。詳細については、正確に一度のみのセマンティクス および ビューサポート のセクションをお読みください。
  • S3 ClickPipes のロール認証は、GCP または Azure にデプロイされた ClickHouse Cloud インスタンスでは利用できません。これは、AWS ClickHouse Cloud インスタンスのみでサポートされます。
  • ClickPipes は、サイズが 10GB またはそれ以下のオブジェクトの取り込みを試みます。10GB を超えるファイルがある場合、ClickPipes の専用エラーテーブルにエラーが追加されます。
  • S3 / GCS ClickPipes は、S3 テーブル関数 とリスト構文を共有していません。
    • ? — 任意の 1 文字に置き換えます。
    • * — 空文字を含む任意の数の任意の文字に置き換えます。
    • ** — 空文字を含む任意の数の任意の文字に置き換えます。
注記

これは有効なパスです:

https://datasets-documentation.s3.eu-west-3.amazonaws.com/http/**.ndjson.gz

これは無効なパスです。{N..M} は ClickPipes ではサポートされていません。

https://datasets-documentation.s3.eu-west-3.amazonaws.com/http/{documents-01,documents-02}.ndjson.gz

継続的取り込み

ClickPipes は、S3 と GCS の両方からの継続的な取り込みをサポートしています。これを有効にすると、ClickPipes は指定されたパスからデータを継続的に取り込み、30秒ごとに新しいファイルをポーリングします。ただし、新しいファイルは最後に取り込まれたファイルよりも辞書的に大きくなければならず、すなわち、取り込み順序を定義するように名前を付ける必要があります。たとえば、file1file2file3 などと名付けられたファイルは、順次取り込まれます。file0 という名前の新しいファイルが追加された場合、ClickPipes はそれを取り込みません。なぜなら、それは最後に取り込んだファイルよりも辞書的に大きくないからです。

アーカイブテーブル

ClickPipes は、宛先テーブルの隣に s3_clickpipe_<clickpipe_id>_archive という接尾辞を持つテーブルを作成します。このテーブルには、ClickPipe によって取り込まれたすべてのファイルのリストが含まれます。このテーブルは、取り込み中のファイルを追跡するために使用され、ファイルが正常に取り込まれたことを確認するためにも使用できます。アーカイブテーブルには 7 日の有効期限 (TTL)があります。

注記

これらのテーブルは ClickHouse Cloud SQL コンソールからは表示されません。HTTPS またはネイティブコネクションを使用して外部クライアント経由で接続して読む必要があります。

認証

S3

公開バケットには構成なしでアクセスできますが、保護されたバケットには IAM 資格情報 または IAM ロールを使用できます。データにアクセスするために必要な権限を理解するには、このガイドを参照してください

GCS

S3 と同様に、公開バケットには構成なしでアクセスできますが、保護されたバケットには AWS IAM 資格情報の代わりに HMAC キーを使用できます。非公開バケットに認証する際は、HMAC (IAM) 資格情報を使用する必要があります。HMAC 資格情報に付与されたサービスアカウントの権限は storage.objects.list および storage.objects.get である必要があります。

F.A.Q.

  • ClickPipes は gs:// で始まる GCS バケットをサポートしていますか?

いいえ。相互運用性の理由から、gs:// バケットのプレフィックスを https://storage.googleapis.com/ に置き換えることをお勧めします。

  • GCS 公開バケットにはどのような権限が必要ですか?

allUsers には適切なロールの割り当てが必要です。roles/storage.objectViewer ロールはバケットレベルで付与されるべきです。このロールは、ClickPipes がオンボーディングと取り込みに必要なバケット内のすべてのオブジェクトを一覧表示できるようにする storage.objects.list 権限を提供します。このロールには、バケット内の個々のオブジェクトを読み取ったりダウンロードしたりするために必要な storage.objects.get 権限も含まれています。詳細については、Google Cloud アクセス制御を参照してください。