メインコンテンツへスキップ
ClickHouse はデータをディスクに保存しているため、ディスクをバックアップする方法は数多くあります。 ここでは、過去に利用されてきた代替手段の一部を紹介します。 ユースケースによっては、こうした方法が適している場合があります。

ソースデータを別の場所に複製する

多くの場合、ClickHouse に取り込まれるデータは、Apache Kafka のような永続的な キューを介して配信されます。この場合、ClickHouse への書き込みと並行して同じ データストリームを読み取り、別の場所のコールドストレージに保存する追加のサブスクライバー群を 構成できます。ほとんどの企業では、推奨される標準的なコールドストレージがすでに決まっており、 それはオブジェクトストアや、HDFS のような分散ファイルシステムであることが一般的です。

ファイルシステムのスナップショット

一部のローカルファイルシステムはスナップショット機能を備えています (たとえば ZFS) 。 ただし、ライブクエリを処理する用途には必ずしも最適ではありません。考えられる解決策の 1 つは、 この種のファイルシステムを使う追加のレプリカを作成し、 SELECT クエリに使用される Distributed テーブルから それらを除外することです。 このようなレプリカ上のスナップショットには、データを変更するクエリからアクセスできません。 さらに、こうしたレプリカでは、server ごとに接続するディスク数を増やした 特別なハードウェア構成を採用できる可能性があり、コスト効率も高くなります。 データ量が少ない場合は、リモートテーブルに対する単純な INSERT INTO ... SELECT ... でも十分機能することがあります。

パーツの操作

ClickHouse では、ALTER TABLE ... FREEZE PARTITION ... クエリを使用して、 テーブルのパーティションのローカルコピーを作成できます。これは /var/lib/clickhouse/shadow/ フォルダへのハードリンクを使って実装されているため、通常、既存データのために追加のディスク容量を消費することはありません。作成された ファイルのコピーは ClickHouse サーバーによって管理されないため、そのまま残しておくこともできます。 そうすれば、追加の外部システムを必要としないシンプルなバックアップになりますが、 ハードウェア障害には依然として弱いままです。このため、 それらを別の場所へリモートコピーしてから、ローカルコピーを削除するのが望ましいです。 この用途には、分散ファイルシステムやオブジェクトストレージも引き続き有力な選択肢ですが、 十分な容量を備えた通常のファイルサーバーでも問題なく使える場合があります (この場合、転送はネットワークファイルシステム、または場合によっては rsync 経由で行われます) 。 データは、ALTER TABLE ... ATTACH PARTITION ... を使用してバックアップから復元できます。 パーティション操作に関連するクエリの詳細については、 ALTER ドキュメントを参照してください。 この方法を自動化するためのサードパーティーツールとして、clickhouse-backup が利用できます。
最終更新日 2026年6月10日