本記事では、obshell-sdk-pythonを使用してクラスタ内の特定ノードを削除する方法について説明します。
説明
まずは obshell-sdk-pythonクイックスタート を参照し、obshell-sdk-pythonの使用方法を確認することを推奨します。
注意事項
クラスタを縮小する前に、以下の要件に注意する必要があります:
リクエストのクライアントに対応するノードは、縮小対象のクラスタ内に存在し、削除対象のノードであってはなりません。つまり、ノード自身がクラスタから自分自身を削除することはできません。
obshellは正常に実行されている必要があります。
サンプルコード
タスクの同期実行
タスクの非同期実行
from obshell import ClientSet
from obshell.auth import PasswordAuth
# クライアントインスタンスを作成します。ノードアドレスは'10.10.10.1'、ポートは2886です。
# クラスタのroot@sysパスワードは'****'です。
client = ClientSet("10.10.10.1", 2886, PasswordAuth("****"))
# ノード'10.10.10.3:2886'をクラスタから削除します。
client.v1.scale_in_sync("10.10.10.3", 2886)
from obshell import ClientSet
from obshell.auth import PasswordAuth
# クライアントインスタンスを作成します。ノードアドレスは '10.10.10.1'、ポートは2886です。
# クラスタのroot@sysパスワードは '****' です。
client = ClientSet("10.10.10.1", 2886, PasswordAuth("****"))
# ノード '10.10.10.3:2886' をクラスタから削除します。
dag = client.v1.scale_in("10.10.10.3", 2886)
# タスク完了を待機します。
if dag is not None:
client.v1.wait_dag_succeed(dag.generic_id)