Object Storage Service (OSS) バケットが不要になった場合は、不要な料金が発生しないように削除できます。
注意事項
このトピックのサンプルコードでは、中国 (杭州) リージョンのリージョン ID
cn-hangzhouを使用しています。デフォルトでは、パブリックエンドポイントを使用してバケット内のリソースにアクセスします。同じリージョン内の他の Alibaba Cloud サービスを使用してバケット内のリソースにアクセスする場合は、内部エンドポイントを使用します。 OSS のリージョンとエンドポイントの詳細については、「OSS のリージョンとエンドポイント」をご参照ください。このトピックでは、アクセス認証情報は環境変数から取得されます。アクセス認証情報を構成する方法の詳細については、「アクセス認証情報を構成する」をご参照ください。
バケット名は一意である必要があります。バケットが削除されると、その名前は他のユーザーが使用できるようになります。名前を引き続き使用する場合は、バケットを削除するのではなく、空にすることをお勧めします。
削除されたバケットは復元できません。削除する前に、バケット内のデータが不要になったことを確認してください。バケット内のデータを引き続き使用する場合は、事前にデータをバックアップしてください。詳細については、「バケットをバックアップする」をご参照ください。
oss:DeleteBucket権限は、バケットの削除に必要です。詳細については、「RAM ユーザーにカスタムポリシーをアタッチする」をご参照ください。
権限
デフォルトでは、Alibaba Cloud アカウントにはすべての権限があります。Alibaba Cloud アカウントの RAM ユーザーまたは RAM ロールには、デフォルトでは権限がありません。Alibaba Cloud アカウントまたはアカウント管理者は、RAM ポリシーまたは バケットポリシーを通じて操作権限を付与する必要があります。
API | アクション | 定義 |
DeleteBucket |
| バケットを削除します。 |
RAM ユーザーが RAM ポリシーで oss:DeleteBucket 権限を持っているにもかかわらずバケットを削除できない場合は、RAM ユーザーにアタッチされている別のバケットポリシーに、効果が「拒否」である oss:DeleteBucket 権限が含まれている可能性があります。この場合は、バケットを削除する前に、「拒否」を「許可」に変更するか、バケットポリシーを削除する必要があります。
前提条件
バケット内のすべてのオブジェクトが削除されていること。
重要バージョン管理されたバケットを削除するには、バケット内のすべての現在および以前のバージョンのオブジェクトが削除されていることを確認してください。詳細については、「バージョン管理」をご参照ください。
バケットに少数のオブジェクトが含まれている場合は、手動で削除することをお勧めします。詳細については、「オブジェクトを削除する」をご参照ください。
バケットに多数のオブジェクトが含まれている場合は、ライフサイクルルールを構成してオブジェクトを削除することをお勧めします。詳細については、「ライフサイクル」をご参照ください。
バケット内のマルチパートアップロードまたは再開可能なアップロードタスクによって生成されたパーツが削除されていること。詳細については、「パーツを削除する」をご参照ください。
メソッド
func (c *Client) DeleteBucket(ctx context.Context, request *DeleteBucketRequest, optFns ...func(*Options)) (*DeleteBucketResult, error)リクエストパラメーター
パラメーター | タイプ | 説明 |
ctx | context.Context | リクエストのコンテキスト。リクエストの合計期間を指定するために使用できます。 |
request | *DeleteBucketRequest | 特定の API 操作のパラメーター。詳細については、DeleteBucketRequest をご参照ください。 |
optFns | ...func(*Options) | オプション。操作レベルのパラメーター。詳細については、Options をご参照ください。 |
レスポンスパラメーター
パラメーター | タイプ | 説明 |
result | *DeleteBucketResult | 操作に対するレスポンス。このパラメーターは、err の値が nil の場合に有効です。詳細については、DeleteBucketResult をご参照ください。 |
err | error | リクエストのステータス。リクエストが失敗した場合、err の値は nil ではありません。 |
サンプルコード
次のコードは、バケットを削除する方法の例を示しています。
package main
import (
"context"
"flag"
"log"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)
var (
region string
bucketName string
)
func init() {
// コマンドラインパラメーターを定義して、バケットのリージョンと名前を指定します。
flag.StringVar(®ion, "region", "", "バケットが配置されているリージョン。")
flag.StringVar(&bucketName, "bucket", "", "バケットの名前。")
}
func main() {
// コマンドラインパラメーターを解析します。
flag.Parse()
// バケットの名前が指定されているかどうかを確認します。
if len(bucketName) == 0 {
flag.PrintDefaults()
log.Fatalf("無効なパラメーター、バケット名が必要です")
}
// リージョンが指定されているかどうかを確認します。
if len(region) == 0 {
flag.PrintDefaults()
log.Fatalf("無効なパラメーター、リージョンが必要です")
}
// デフォルトの構成を読み込み、認証情報プロバイダーとリージョンを指定します。
cfg := oss.LoadDefaultConfig().
WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
WithRegion(region)
// OSS クライアントを作成します。
client := oss.NewClient(cfg)
// 削除のリクエストオブジェクトを作成します。
request := &oss.DeleteBucketRequest{
Bucket: oss.Ptr(bucketName),
}
// DeleteBucket メソッドを呼び出します。
result, err := client.DeleteBucket(context.TODO(), request)
if err != nil {
log.Fatalf("バケットの削除に失敗しました %v", err)
}
// 結果を表示します。
log.Printf("バケットの削除結果:%#v\n", result)
}
関連情報
バケットの削除に使用される完全なサンプルコードについては、GitHub サンプル をご参照ください。
バケットの削除のために呼び出すことができる API 操作の詳細については、DeleteBucket をご参照ください。