メインコンテンツまでスキップ
バージョン: 4.x

バックエンドの廃止

デスクリプション

このステートメントは、クラスターからBEノードを安全に廃止するために使用されます。この操作は非同期です。

Syntax

ALTER SYSTEM DECOMMISSION BACKEND "<be_identifier>" [, "<be_identifier>" ... ]

どこで:

be_identifier
: "<be_host>:<be_heartbeat_port>"
| "<backend_id>"

必須パラメータ

1. <be_host>

BE ノードのホスト名または IP アドレスを指定できます。

2. <heartbeat_port>

BE ノードのハートビートポートです。デフォルトは 9050 です。

3. <backend_id>

BE ノードの ID です。

ヒント

<be_host><be_heartbeat_port>、および <backend_id> はすべて SHOW BACKENDS ステートメントでクエリして取得できます。

アクセス制御要件

この SQL を実行するユーザーは、少なくとも以下の権限を持つ必要があります:

PrivilegeObject注釈
NODE_PRIV

使用上の注意

  1. このコマンドを実行した後、SHOW BACKENDS ステートメントを使用して廃止状況(SystemDecommissioned 列の値が true)と廃止の進行状況(TabletNum 列の値が徐々に 0 まで下がります)を確認できます。
  2. 通常の状況では、TabletNum 列の値が 0 まで下がった後、この BE ノードは削除されます。Doris が自動的に BE を削除することを望まない場合は、FE Master の設定 drop_backend_after_decommission を false に変更できます。
  3. 現在の BE が比較的大量のデータを保存している場合、DECOMMISSION 操作は数時間または数日間続く可能性があります。
  4. DECOMMISSION 操作の進行が停滞した場合、具体的には SHOW BACKENDS ステートメントの TabletNum 列が特定の値で固定されたままの場合、以下のような状況が原因である可能性があります:
    • 現在の BE 上のタブレットを移行するのに適した他の BE がありません。例えば、3 つのレプリカを持つTableがある 3 ノードクラスターで、そのうちの 1 つのノードを廃止する場合、このノードは他の BE にデータを移行することができません(他の 2 つの BE はすでにそれぞれ 1 つのレプリカを持っています)。
    • 現在の BE 上のタブレットがまだゴミ箱にあります。ゴミ箱を空にしてから廃止を待つことができます。
    • 現在の BE 上のタブレットが大きすぎるため、単一タブレットの移行が常にタイムアウトし、このタブレットを移行できません。FE Master の設定 max_clone_task_timeout_sec をより大きな値に調整できます(デフォルトは 7200 秒です)。
    • 現在の BE のタブレットに未完了のトランザクションがあります。トランザクションの完了を待つか、手動でトランザクションを中止できます。
    • その他の場合、FE Master のログでキーワード replicas to decommission をフィルタリングして異常なタブレットを見つけ、SHOW TABLET ステートメントを使用してこのタブレットが属するTableを見つけ、その後新しいTableを作成し、古いTableから新しいTableにデータを移行し、最後に DROP TABLE FORCE を使用して古いTableを削除できます。

  1. BE の Host と HeartbeatPort に従って、クラスターから 2 つのノードを安全に廃止します。

    ALTER SYSTEM DECOMMISSION BACKEND "192.168.0.1:9050", "192.168.0.2:9050";
  2. BEのIDに従って、クラスタからノードを安全に廃止する。

    ALTER SYSTEM DECOMMISSION BACKEND "10002";