StarRocks のアップグレード
このトピックでは、StarRocks クラスタをアップグレードする方法について説明します。
概要
アップグレードの前にこのセクションの情報を確認し、推奨されるアクションを実行してください。
StarRocks のバージョン
StarRocks のバージョンは、Major.Minor.Patch という形式の3つの数字で表されます。例えば、2.5.4
です。最初の数字は StarRocks のメジャーバージョンを表し、2番目の数字はマイナーバージョンを表し、3番目の数字はパッチバージョンを表します。
注意
既存の共有なしクラスタを共有データクラスタにアップグレードすることはできませんし、その逆もできません。新しい共有データクラスタをデプロイする必要があります。
アップグレードパス
-
パッチバージョンのアップグレードの場合
StarRocks クラスタをパッチバージョン間でアップグレードできます。例えば、v2.2.6 から直接 v2.2.11 へ。
-
マイナーバージョンのアップグレードの場合
StarRocks v2.0 以降、StarRocks クラスタをマイナーバージョン間でアップグレードできます。例えば、v2.2.x から直接 v2.5.x へ。ただし、互換性と安全性の理由から、StarRocks クラスタを マイナーバージョンごとに順次 アップグレードすることを強くお勧めします。例えば、StarRocks v2.2 クラスタを v2.5 にアップグレードするには、次の順序でアップグレードする必要があります: v2.2.x --> v2.3.x --> v2.4.x --> v2.5.x。
-
メジャーバージョンのアップグレードの場合
StarRocks クラスタを v3.0 にアップグレードするには、まず v2.5 にアップグレードする必要があります。
注意
例えば、2.4->2.5->3.0->3.1->3.2 のように連続したマイナーバージョンのアップグレードを行う必要がある場合、またはアップグレードに失敗してクラスタをダウングレードした後に再度アップグレードしたい場合、例えば、2.5->3.0->2.5->3.0 のように。Follower FE のメタデータアップグレードの失敗を防ぐために、2つの連続したアップグレードの間、または2回目のアップグレードの試行前にダウングレード後に次の手順を実行してください:
- ALTER SYSTEM CREATE IMAGE を実行して新しいイメージを作成します。
- 新しいイメージがすべての Follower FE に同期されるのを待ちます。
イメージファイルが同期されたかどうかは、Leader FE のログファイル fe.log を確認することで確認できます。「push image.* from subdir [] to other nodes. totally xx nodes, push successful xx nodes」というログの記録があれば、イメージファイルが正常に同期されたことを示しています。
アップグレード手順
StarRocks は ローリングアップグレード をサポートしており、サービスを停止せずにクラスタをアップグレードできます。設計上、BEs と CNs は FEs と後方互換性があります。したがって、クラスタを正常に動作させながらアップグレードするために、最初に BEs と CNs をアップグレードし、その後に FEs をアップグレード する必要があります。逆の順序でアップグレードすると、FEs と BEs/CNs の間で互換性がなくなり、サービスがクラッシュする可能性があります。FE ノードについては、Leader FE ノードをアップグレードする前に、すべての Follower FE ノードを最初にアップグレードする必要があります。
始める前に
準備中、マイナーまたはメジャーバージョンのアップグレードを行う場合は、互換性のある設定を行う必要があります。また、クラスタ内のすべてのノードをアップグレードする前に、FEs と BEs のいずれかでアップグレードの可用性テストを実行する必要があります。
互換性設定を実行する
StarRocks クラスタを後のマイナーまたはメジャーバージョンにアップグレードしたい場合は、互換性設定を実行する必要があります。一般的な互換性設定に加えて、アップグレード元の StarRocks クラスタのバージョンに応じて詳細な設定が異なります。
- 一般的な互換性設定
StarRocks クラスタをアップグレードする前に、tablet クローンを無効にする必要があります。バランサーを無効にしている場合は、この手順をスキップできます。
ADMIN SET FRONTEND CONFIG ("tablet_sched_max_scheduling_tablets" = "0");
ADMIN SET FRONTEND CONFIG ("tablet_sched_max_balancing_tablets" = "0");
ADMIN SET FRONTEND CONFIG ("disable_balance"="true");
ADMIN SET FRONTEND CONFIG ("disable_colocate_balance"="true");
アップグレード後、すべての BE ノードのステータスが Alive
になったら、tablet クローンを再度有効にできます。
ADMIN SET FRONTEND CONFIG ("tablet_sched_max_scheduling_tablets" = "10000");
ADMIN SET FRONTEND CONFIG ("tablet_sched_max_balancing_tablets" = "500");
ADMIN SET FRONTEND CONFIG ("disable_balance"="false");
ADMIN SET FRONTEND CONFIG ("disable_colocate_balance"="false");
- v2.0 から後のバージョンにアップグレードする場合
StarRocks v2.0 クラスタをアップグレードする前に、次の BE 設定とシステム変数を設定する必要があります。
-
BE 設定項目
vector_chunk_size
を変更している場合は、アップグレード前に4096
に設定する必要があります。これは静的パラメータであるため、BE 設定ファイル be.conf で変更し、ノードを再起動して変更を有効にする必要があります。 -
システム変数
batch_size
をグローバルに4096
以下に設定します。SET GLOBAL batch_size = 4096;
BE のアップグレード
アップグレードの可用性テストに合格したら、クラスタ内の BE ノードを最初にアップグレードできます。
-
BE ノードの作業ディレクトリに移動し、ノードを停止します。
# <be_dir> を BE ノードのデプロイメントディレクトリに置き換えます。
cd <be_dir>/be
./bin/stop_be.sh -
bin と lib の下の元のデプロイメントファイルを新しいバージョンのものに置き換えます。
mv lib lib.bak
mv bin bin.bak
cp -r /tmp/StarRocks-x.x.x/be/lib .
cp -r /tmp/StarRocks-x.x.x/be/bin . -
BE ノードを起動します。
sh bin/start_be.sh --daemon
-
BE ノードが正常に起動したかどうかを確認します。
ps aux | grep starrocks_be
-
他の BE ノードをアップグレードするために、上記の手順を繰り返します。
CN のアップグレード
-
CN ノードの作業ディレクトリに移動し、ノードを優雅に停止します。
# <cn_dir> を CN ノードのデプロイメントディレクトリに置き換えます。
cd <cn_dir>/be
./bin/stop_cn.sh --graceful -
bin と lib の下の元のデプロイメントファイルを新しいバージョンのものに置き換えます。
mv lib lib.bak
mv bin bin.bak
cp -r /tmp/StarRocks-x.x.x/be/lib .
cp -r /tmp/StarRocks-x.x.x/be/bin . -
CN ノードを起動します。
sh bin/start_cn.sh --daemon
-
CN ノードが正常に起動したかどうかを確認します。
ps aux | grep starrocks_be
-
他の CN ノードをアップグレードするために、上記の手順を繰り返します。
FE のアップグレード
すべての BE と CN ノードをアップグレードした後、FE ノードをアップグレードできます。まず Follower FE ノードをアップグレードし、その後 Leader FE ノードをアップグレードする必要があります。
-
FE ノードの作業ディレクトリに移動し、ノードを停止します。
# <fe_dir> を FE ノードのデプロイメントディレクトリに置き換えます。
cd <fe_dir>/fe
./bin/stop_fe.sh -
bin、lib、および spark-dpp の下の元のデプロイメントファイルを新しいバージョンのものに置き換えます。
mv lib lib.bak
mv bin bin.bak
mv spark-dpp spark-dpp.bak
cp -r /tmp/StarRocks-x.x.x/fe/lib .
cp -r /tmp/StarRocks-x.x.x/fe/bin .
cp -r /tmp/StarRocks-x.x.x/fe/spark-dpp . -
FE ノードを起動します。
sh bin/start_fe.sh --daemon
-
FE ノードが正常に起動したかどうかを確認します。
ps aux | grep StarRocksFE
-
他の Follower FE ノードをアップグレードし、最後に Leader FE ノードをアップグレードするために、上記の手順を繰り返します。