すべてのプロダクト
Search
ドキュメントセンター

Object Storage Service:リソースグループの設定

最終更新日:Aug 13, 2025

このトピックでは、Object Storage Service (OSS) バケットのリソースグループを構成し、バケットが属するリソースグループの ID をクエリする方法について説明します。

注意事項

  • このトピックのサンプルコードでは、中国 (杭州) リージョンのリージョン ID cn-hangzhou を使用しています。デフォルトでは、パブリックエンドポイントを使用してバケット内のリソースにアクセスします。バケットが配置されているのと同じリージョン内の他の Alibaba Cloud サービスを使用してバケット内のリソースにアクセスする場合は、内部エンドポイントを使用します。 OSS でサポートされているリージョンとエンドポイントの詳細については、「OSS のリージョンとエンドポイント」をご参照ください。

  • バケットのリソースグループを構成するには、oss:PutBucketResourceGroup 権限が必要です。バケットが属するリソースグループの ID をクエリするには、oss:GetBucketResourceGroup 権限が必要です。詳細については、「RAM ユーザーにカスタムポリシーをアタッチする」をご参照ください。

サンプルコード

バケットが属するリソースグループを構成する

重要

バケットのリソースグループを構成するときにリソースグループ 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()  # スクリプトのエントリポイント。制御フローはここから開始されます。

バケットが属するリソースグループの ID をクエリする

バケットが属するリソースグループの ID をクエリするためのサンプルコードを以下に示します。

import argparse
import alibabacloud_oss_v2 as oss

# コマンドライン引数パーサーを作成し、スクリプトの目的を記述します。この例では、バケットのリソースグループ構成をクエリする方法について説明します。
parser = argparse.ArgumentParser(description="get bucket resource group sample")

# コマンドライン引数を定義します。必須パラメーター(リージョン、バケット名)とオプションのエンドポイントパラメーターを含めます。
parser.add_argument('--region', help='バケットが配置されているリージョン。', required=True)
parser.add_argument('--bucket', help='バケットの名前。', required=True)
parser.add_argument('--endpoint', help='他のサービスが OSS にアクセスするために使用できるドメイン名')

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

    # 前述の設定を使用して、OSS Client インスタンスを初期化します。
    client = oss.Client(cfg)

    # バケットのリソースグループをクエリするリクエストを送信します。
    result = client.get_bucket_resource_group(oss.GetBucketResourceGroupRequest(
            bucket=args.bucket,  # バケットの名前。
    ))

    # HTTP ステータスコード、リクエスト ID、リソースグループ ID を表示して、リクエストの状態と構成の詳細を確認します。
    print(f'status code: {result.status_code},'
          f' request id: {result.request_id},'
          f' resource group id: {getattr(result.bucket_resource_group_configuration, "resource_group_id", "Not set")},'
          )

# スクリプトが直接実行されたときに main 関数を呼び出して、処理ロジックを開始します。
if __name__ == "__main__":
    main()  # スクリプトのエントリポイント。制御フローはここから開始されます。

関連情報

  • バケットのリソースグループを構成するために使用される完全なサンプルコードについては、「put_bucket_resource_group.py」を参照してください。

  • バケットが属するリソースグループの ID をクエリするために使用される完全なサンプルコードについては、「get_bucket_resource_group.py」を参照してください。