本記事では、obshell-sdk-goを使用してテナントレプリカを追加する方法について説明します。一括で追加することも可能です。
説明
まずは obshell-sdk-goクイックスタート を参照し、obshell-sdk-goの使い方を確認することをお勧めします。
注意事項
obshellが正常に実行されていることを確認してください。
テナントが存在し、状態がNORMALであることを確認してください。
リクエストのクライアントに対応するノードは、初期化済みのクラスタ内にある必要があります。
サンプルコード
タスクの同期実行
タスクの非同期実行
package main
import (
"fmt"
"github.com/oceanbase/obshell-sdk-go/services"
"github.com/oceanbase/obshell-sdk-go/services/v1"
)
func main() {
// クライアントインスタンスを作成します。ノードアドレスは'10.10.10.1'、ポートは2886です。
client, err := services.NewClientWithPassword("10.10.10.1", 2886, "****")
if err != nil {
fmt.Print(err)
return
}
req := client.V1().NewScaleOutReplicasRequest("t1", []v1.ZoneParam{
{
Name: "zone2",
ReplicaType: "FULL",
UnitConfigName: "s1",
UnitNum: 1,
},
{
Name: "zone3",
ReplicaType: "READONLY",
UnitConfigName: "s1",
UnitNum: 1,
},
})
if _, err = client.V1().ScaleOutReplicasSyncWithRequest(req); err != nil {
fmt.Print(err)
return
}
}
package main
import (
"fmt"
"github.com/oceanbase/obshell-sdk-go/services"
"github.com/oceanbase/obshell-sdk-go/services/v1"
)
func main() {
// クライアントインスタンスを作成します。ノードアドレスは'10.10.10.1'、ポートは2886です。
client, err := services.NewClientWithPassword("10.10.10.1", 2886, "****")
if err != nil {
fmt.Print(err)
return
}
req := client.V1().NewScaleOutReplicasRequest("t1", []v1.ZoneParam{
{
Name: "zone2",
ReplicaType: "FULL",
UnitConfigName: "s1",
UnitNum: 1,
},
{
Name: "zone3",
ReplicaType: "READONLY",
UnitConfigName: "s1",
UnitNum: 1,
},
})
dag, err := client.V1().ScaleOutReplicasWithRequest(req)
if err != nil {
fmt.Print(err)
return
}
// タスクが成功するまで待機します。
if _, err = client.V1().WaitDagSucceed(dag.GenericID); err != nil {
fmt.Print(err)
return
}
}
関連ドキュメント
テナントレプリカの追加に関するAPIインターフェースの説明については、テナントレプリカの追加を参照してください。
obshell-sdk-pythonを使用したAPIメソッドのリクエスト方法の紹介については、テナントレプリカの追加を参照してください。