當您不再需要保留某個儲存空間(Bucket)時,可將其刪除,以免產生額外費用。
Bucket名稱具有唯一性,因此Bucket刪除後名稱可能被其他使用者使用。如果您希望繼續使用該名稱,建議您清空Bucket而非刪除。
刪除Bucket後,Bucket中的資料無法恢複,請在刪除前確認資料已不再使用。如果需要繼續使用Bucket中的資料,請提前做好備份。關於備份的更多資訊,請參見備份儲存空間。
注意事項
本文以華東1(杭州)外網Endpoint為例。如果您希望通過與OSS同地區的其他阿里雲產品訪問OSS,請使用內網Endpoint。關於OSS支援的Region與Endpoint的對應關係,請參見OSS地區和訪問網域名稱。
本文以OSS網域名稱建立OSSClient為例。如果您希望通過自訂網域名、STS等方式建立OSSClient,請參見建立OssClient。
要刪除儲存空間,您必須有
oss:DeleteBucket
許可權。具體操作,請參見為RAM使用者授權自訂的權限原則。
前提條件
已刪除Bucket的存取點。具體操作,請參見存取點概述。
已刪除Bucket的所有檔案(Object)。
重要如果Bucket已開啟版本控制,請確保刪除Bucket中的所有目前的版本和歷史版本檔案。具體操作,請參見版本控制概述。
已刪除Bucket的所有因分區上傳或斷點續傳產生的片段(Part)。具體操作,請參見刪除片段。
已刪除Bucket的所有Livechannel。具體操作,請參見DeleteLiveChannel。
已具有
oss:DeleteBucket
許可權。具體操作,請參見為RAM使用者授權自訂的權限原則。說明如果您在RAM Policy中擁有
oss:DeleteBucket
許可權但仍然無法刪除Bucket,則Bucket Policy可能包含授權效力為Deny的oss:DeleteBucket
許可權。您必須將Deny修改為Allow或者直接刪除此Bucket Policy,然後才能刪除此Bucket。
範例程式碼
以下代碼用於刪除儲存空間examplebucket:
#include <alibabacloud/oss/OssClient.h>
using namespace AlibabaCloud::OSS;
int main(void)
{
/*初始化OSS帳號資訊。*/
/*yourEndpoint填寫Bucket所在地區對應的Endpoint。以華東1(杭州)為例,Endpoint填寫為https://oss-cn-hangzhou.aliyuncs.com。*/
std::string Endpoint = "yourEndpoint";
/ *yourRegion填寫Bucket所在地區對應的Region。以華東1(杭州)為例,Region填寫為cn - hangzhou。 * /
std::string Region = "yourRegion";
/*填寫Bucket名稱,例如examplebucket。*/
std::string BucketName = "examplebucket";
/*初始化網路等資源。*/
InitializeSdk();
ClientConfiguration conf;
conf.signatureVersion = SignatureVersionType::V4;
/* 從環境變數中擷取訪問憑證。運行本程式碼範例之前,請確保已設定環境變數OSS_ACCESS_KEY_ID和OSS_ACCESS_KEY_SECRET。*/
auto credentialsProvider = std::make_shared<EnvironmentVariableCredentialsProvider>();
OssClient client(Endpoint, credentialsProvider, conf);
client.SetRegion(Region);
/*刪除Bucket。*/
DeleteBucketRequest request(BucketName);
auto outcome = client.DeleteBucket(request);
if (outcome.isSuccess()) {
std::cout << "Delete bucket successfully." << std::endl;
} else {
std::cout << "Failed to delete bucket. Error code: " << outcome.error().Code()
<< ", Message: " << outcome.error().Message()
<< ", RequestId: " << outcome.error().RequestId() << std::endl;
}
/*釋放網路等資源。*/
ShutdownSdk();
return 0;
}
相關文檔
關於刪除Bucket的完整範例程式碼,請參見GitHub樣本。
關於刪除Bucket的API介面說明,請參見DeleteBucket。