StarRocks のアップグレード
このトピックでは、StarRocks クラスタをアップグレードする方法について説明します。
概要
アップグレードする前にこのセクションの情報を確認し、推奨されるアクションを実行してください。
StarRocks のバージョン
StarRocks のバージョンは、Major.Minor.Patch の形式で表され、例えば 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 ノードの場合、まずすべての Follower FE ノードをアップグレードしてから Leader 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 ノードをアップグレードするために、上記の手順を繰り返します。