本記事では、obshell-sdk-goを使用してクラスタ内の特定ノードを削除する方法について説明します。
説明
package main
import (
"github.com/oceanbase/obshell-sdk-go/services"
)
func main() {
// クライアントインスタンスを作成します。ノードのアドレスは '10.10.10.1'、ポートは2886です。
// 所在クラスタのroot@sysパスワードは '****' です。
client, err := services.NewClientWithPassword("10.10.10.1", 2886, "****")
if err != nil {
panic(err)
}
// ノード '10.10.10.3:2886' をクラスタから削除します。
req := client.V1().NewScaleInRequest("10.10.10.3", 2886)
if _, err = client.V1().ScaleInSyncWithRequest(req); err != nil {
panic(err)
}
}
package main
import (
"github.com/oceanbase/obshell-sdk-go/services"
)
func main() {
// クライアントインスタンスを作成します。ノードのアドレスは '10.10.10.1'、ポートは2886です。
// 所在クラスタのroot@sysパスワードは '****' です。
client, err := services.NewClientWithPassword("10.10.10.1", 2886, "****")
if err != nil {
panic(err)
}
// ノード '10.10.10.3:2886' をクラスタから削除します。
req := client.V1().NewScaleInRequest("10.10.10.3", 2886)
dag, err := client.V1().ScaleInWithRequest(req)
if err != nil {
panic(err)
}
// タスクが正常に完了するのを待ちます。
if dag != nil && dag.GenericDTO != nil {
if _, err = client.V1().WaitDagSucceed(dag.GenericID); err != nil {
panic(err)
}
}
}
関連ドキュメント
obshell-sdk-pythonを使用したAPIメソッドのリクエスト方法については、クラスタのスケールインを参照してください。