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

Object Storage Service:OSS SDK for Go 2.0 を使用してバケットを削除する

最終更新日:Aug 06, 2025

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

oss: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(&region, "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 をご参照ください。