重要 バケットのリソースグループを構成するときにリソースグループ ID を指定しないと、バケットはデフォルトのリソースグループに属します。バケットを追加する前に、バケットを追加するリソースグループが存在することを確認してください。詳細については、「リソースグループを作成する」をご参照ください。
バケットのリソースグループを構成するためのサンプルコードを以下に示します。
import argparse
import alibabacloud_oss_v2 as oss
# コマンドライン引数パーサーを作成し、スクリプトの目的(バケットのリソースグループの構成)を記述します。
parser = argparse.ArgumentParser(description="put bucket resource group sample")
# コマンドライン引数を定義します。必須パラメーター(リージョン、バケット名)とオプションパラメーター(エンドポイント、リソースグループ ID)を含めます。
parser.add_argument('--region', help='バケットが配置されているリージョン。', required=True)
parser.add_argument('--bucket', help='バケットの名前。', required=True)
parser.add_argument('--endpoint', help='他のサービスが OSS にアクセスするために使用できるドメイン名')
parser.add_argument('--resource_group_id',
help='バケットが属するリソースグループの ID。(オプション、デフォルトは空の文字列)',
default='')
def main():
# コマンドライン引数を解析して、入力された値を取得します。
args = parser.parse_args()
# 認証のために、環境変数からアクセス認証情報をロードします。
credentials_provider = oss.credentials.EnvironmentVariableCredentialsProvider()
# デフォルト構成を使用して cfg オブジェクトを作成し、認証情報プロバイダーを指定します。
cfg = oss.config.load_default()
cfg.credentials_provider = credentials_provider
# cfg オブジェクトのリージョン属性を、コマンドラインで指定されたリージョンに設定します。
cfg.region = args.region
# カスタムエンドポイントが指定されている場合は、cfg オブジェクトのエンドポイント属性を指定されたエンドポイントで更新します。
if args.endpoint is not None:
cfg.endpoint = args.endpoint
# 前述の設定を使用して、OSSClient インスタンスを初期化します。
client = oss.Client(cfg)
# 指定されたバケットのリソースグループを構成するリクエストを送信します。
result = client.put_bucket_resource_group(oss.PutBucketResourceGroupRequest(
bucket=args.bucket, # バケットの名前。
bucket_resource_group_configuration=oss.BucketResourceGroupConfiguration(
resource_group_id=args.resource_group_id, # リソースグループ ID。
),
))
# 操作の HTTP ステータスコードとリクエスト ID を表示して、リクエストの状態を確認します。
print(f'status code: {result.status_code},'
f' request id: {result.request_id},'
)
# スクリプトが直接実行されたときに main 関数を呼び出して、処理ロジックを開始します。
if __name__ == "__main__":
main() # スクリプトのエントリポイント。制御フローはここから開始されます。