本記事では、obshell-sdk-goを使用してクラスタを停止する方法について説明します。
説明
package main
import (
"github.com/oceanbase/obshell-sdk-go/services"
"github.com/oceanbase/obshell-sdk-go/services/v1"
)
func main() {
// クライアントインスタンスを作成します。ノードのアドレスは '10.10.10.1'、ポートは2886です。
// 所在クラスタのroot@sysパスワードは '****' です。
client, err := services.NewClientWithPassword("10.10.10.1", 2886, "***")
if err != nil {
panic(err)
}
// クラスタ内のすべてのOBServerノードを強制的に停止します。
req := client.V1().NewStopRequest(v1.SCOPE_GLOBAL).SetForce()
if _, err = client.V1().StopSyncWithRequest(req); err != nil {
panic(err)
}
}
package main
import (
"github.com/oceanbase/obshell-sdk-go/services"
"github.com/oceanbase/obshell-sdk-go/services/v1"
)
func main() {
// クライアントインスタンスを作成します。ノードのアドレスは '10.10.10.1'、ポートは2886です。
// 所在クラスタのroot@sysパスワードは '****' です。
client, err := services.NewClientWithPassword("10.10.10.1", 2886, "***")
if err != nil {
panic(err)
}
// クラスタ内のすべてのOBServerノードを強制的に停止します。
req := client.V1().NewStopRequest(v1.SCOPE_GLOBAL).SetForce()
dag, err := client.V1().StopWithRequest(req)
if err != nil {
panic(err)
}
// タスクが成功するまで待機します。
if _, err = client.V1().WaitDagSucceed(dag.GenericID); err != nil {
panic(err)
}
}
関連ドキュメント
-
クラスタ停止のAPIインターフェースについては、クラスタの停止を参照してください。
obshell-sdk-pythonでAPIメソッドをリクエストする方法については、クラスタの停止を参照してください。