移動及重新命名值區

建立值區後,您要永久定義其名稱、地理位置以及所屬的專案。不過實際上還是可以移動或重命名您的值區:

  • 如果在您的舊值區中沒有任何資料,只需刪除值區,再使用新名稱、新位置或新專案建立另一個值區。

  • 如果您的舊值區內有資料,請用所需的名稱、位置和/或專案建立一個新值區,再將舊值區中的資料複製到新值區,然後刪除舊值區及其內容。以下步驟會說明此流程。

    請注意,如果您希望新值區與舊值區有相同的名稱,則必須將資料移動兩次:先在中介值區暫時保存資料,如此即可刪除原始值區,將值區的名稱釋出,以供最終的值區使用。

將資料從一個值區移動到另一個值區:

步驟 1) 建立新值區

主控台

  1. 在 Google Cloud Platform 主控台中開啟 Cloud Storage 瀏覽器。
    開啟 Cloud Storage 瀏覽器
  2. 按一下 [Create Bucket] (建立值區)
  3. 指定「Name」(名稱),名稱必須遵守值區命名規定
  4. 選取值區的「Default storage class」(預設儲存空間級別)。根據預設,系統會指派預設的儲存空間級別給所有上傳到值區的物件。

    注意:按一下 [Compare storage classes] (比較儲存空間級別),即可比較儲存空間級別和每月預估費用。

  5. 指定要儲存值區資料的「Location」(位置)
  6. 新的值區。

  7. 按一下 [Create] (建立)。

gsutil

使用 gsutil mb 指令,並將 [VALUES_IN_BRACKETS] 替換為適當的值:

gsutil mb gs://[BUCKET_NAME]/

設定下列的選用標記,進一步控管值區的建立作業:

  • -p:指定要與您的值區建立關聯的專案。
  • -c:指定值區的預設儲存空間級別
  • -l:指定值區的位置。
  • -b:在您的值區上啟用僅值區政策

例如:

  gsutil mb -p [PROJECT_NAME] -c [STORAGE_CLASS] -l [BUCKET_LOCATION] -b on gs://[BUCKET_NAME]/

程式碼範例

C++

詳情請參閱 Cloud Storage C++ API 參考說明文件

namespace gcs = google::cloud::storage;
using ::google::cloud::StatusOr;
[](gcs::Client client, std::string bucket_name) {
  StatusOr<gcs::BucketMetadata> bucket_metadata =
      client.CreateBucket(bucket_name, gcs::BucketMetadata());

  if (!bucket_metadata) {
    throw std::runtime_error(bucket_metadata.status().message());
  }

  std::cout << "Bucket " << bucket_metadata->name() << " created."
            << "\nFull Metadata: " << *bucket_metadata << "\n";
}

C#

詳情請參閱 Cloud Storage C# API 參考說明文件

private void CreateBucket(string bucketName)
{
    var storage = StorageClient.Create();
    storage.CreateBucket(s_projectId, bucketName);
    Console.WriteLine($"Created {bucketName}.");
}

Go

詳情請參閱 Cloud Storage Go API 參考說明文件

bucket := client.Bucket(bucketName)
if err := bucket.Create(ctx, projectID, &storage.BucketAttrs{
	StorageClass: "COLDLINE",
	Location:     "asia",
}); err != nil {
	return err
}

Java

詳情請參閱 Cloud Storage Java API 參考說明文件

Bucket bucket =
    storage.create(
        BucketInfo.newBuilder(bucketName)
            // See here for possible values: http://g.co/cloud/storage/docs/storage-classes
            .setStorageClass(StorageClass.COLDLINE)
            // Possible values: http://g.co/cloud/storage/docs/bucket-locations#location-mr
            .setLocation("asia")
            .build());

Node.js

詳情請參閱 Cloud Storage Node.js API 參考說明文件

// Imports the Google Cloud client library
const {Storage} = require('@google-cloud/storage');

// Creates a client
const storage = new Storage();

/**
 * TODO(developer): Uncomment the following line before running the sample.
 */
// const bucketName = 'Name of a bucket, e.g. my-bucket';

// Creates a new bucket in the Asia region with the coldline default storage
// class. Leave the second argument blank for default settings.
//
// For default values see: https://cloud.google.com/storage/docs/locations and
// https://cloud.google.com/storage/docs/storage-classes
await storage.createBucket(bucketName, {
  location: 'ASIA',
  storageClass: 'COLDLINE',
});

console.log(`Bucket ${bucketName} created.`);

PHP

詳情請參閱 Cloud Storage PHP API 參考說明文件

use Google\Cloud\Storage\StorageClient;

/**
 * Create a Cloud Storage Bucket.
 *
 * @param string $bucketName name of the bucket to create.
 * @param string $options options for the new bucket.
 *
 * @return Google\Cloud\Storage\Bucket the newly created bucket.
 */
function create_bucket($bucketName, $options = [])
{
    $storage = new StorageClient();
    $bucket = $storage->createBucket($bucketName, $options);
    printf('Bucket created: %s' . PHP_EOL, $bucket->name());
}

Python

詳情請參閱 Cloud Storage Python API 參考說明文件

def create_bucket(bucket_name):
    """Creates a new bucket."""
    storage_client = storage.Client()
    bucket = storage_client.create_bucket(bucket_name)
    print('Bucket {} created'.format(bucket.name))

Ruby

詳情請參閱 Cloud Storage Ruby API 參考說明文件

# project_id    = "Your Google Cloud project ID"
# bucket_name   = "Name of Google Cloud Storage bucket to create"
# location      = "Location of where to create Cloud Storage bucket"
# storage_class = "Storage class of Cloud Storage bucket"

require "google/cloud/storage"

storage = Google::Cloud::Storage.new project_id: project_id
bucket  = storage.create_bucket bucket_name,
                                location:      location,
                                storage_class: storage_class

puts "Created bucket #{bucket.name} in #{location}" +
     " with #{storage_class} class"

REST API

JSON API

如要進一步瞭解可設為值區預設值的儲存空間級別,請參閱儲存空間級別

  1. OAuth 2.0 Playground 取得授權存取憑證,將 Playground 設為使用您自己的 OAuth 憑證。
  2. 建立含有下列資訊的 .json 檔案,並將 [VALUES_IN_BRACKETS] 替換為適當的值:
  3. {
      "name": "[BUCKET_NAME]",
      "location": "[BUCKET_LOCATION]",
      "storageClass": "[STORAGE_CLASS]"
    }
  4. 使用 cURL 呼叫 JSON API,並將 [VALUES_IN_BRACKETS] 替換成適當的值:
    curl -X POST --data-binary @[JSON_FILE_NAME].json \
         -H "Authorization: Bearer [OAUTH2_TOKEN]" \
         -H "Content-Type: application/json" \
         "https://www.googleapis.com/storage/v1/b?project=[PROJECT_ID]"

XML API

如要進一步瞭解可設為值區預設值的儲存空間級別,請參閱儲存空間級別

  1. OAuth 2.0 Playground 取得授權存取憑證,將 Playground 設為使用您自己的 OAuth 憑證。
  2. 建立含有下列資訊的 .xml 檔案,並將 [VALUES_IN_BRACKETS] 替換為適當的值:
  3. <CreateBucketConfiguration>
       <LocationConstraint>[BUCKET_LOCATION]</LocationConstraint>
       <StorageClass>[STORAGE_CLASS]</StorageClass>
    </CreateBucketConfiguration>
  4. 使用 cURL 呼叫 XML API,並將 [VALUES_IN_BRACKETS] 替換成適當的值:
    curl -X PUT --data-binary @[XML_FILE_NAME].xml \
         -H "Authorization: Bearer [OAUTH2_TOKEN]" \
         -H "x-goog-project-id: [PROJECT_ID]" \
         "https://storage.googleapis.com/[BUCKET_NAME]"

步驟 2) 將檔案從舊值區複製到新值區

主控台

請使用 Google Cloud Platform 主控台中的 Cloud Storage 移轉服務,將資料從 Cloud Storage 值區複製到另一個值區:

  1. 開啟 Google Cloud Platform 主控台中的「移轉」頁面。

    開啟「移轉」頁面

  2. 按一下 [建立轉移工作]
  3. 按照逐步操作說明,在完成每個步驟時按一下 [繼續]

    • 選取來源:選擇 Google Cloud Storage 值區 做為來源,然後按一下 [瀏覽] 以尋找並選取要移出檔案的值區。

    • 選取目的地:按一下 [瀏覽],以尋找並選取要將檔案移入的值區。

      此外,請選取「轉移作業完成後刪除來源物件」的核取方塊。

    • 設定轉移:您可以忽略此部分。

  4. 逐步完成操作後,請按一下 [建立]

    如此將檔案從舊值區複製到新值區的流程即會開始。這個流程可能需要一些時間;不過在按一下 [建立]後,您就可以離開 Google Cloud Platform 主控台。

查看移轉的進度:在 Google Cloud Platform 主控台中開啟「移轉」頁面。

開啟「移轉」頁面

gsutil

  1. 確認已安裝 gsutil 4.12 或更高版本。
  2. 請使用具有 -r 選項的 gsutil cp 指令,以遞迴方式將所有檔案從來源值區複製到目標值區,再將 [VALUES_IN_BRACKETS] 取代為適當的值:

    gsutil cp -r gs://[SOURCE_BUCKET]/* gs://[DESTINATION_BUCKET]

REST API

JSON API

請使用 JSON API 的 rewrite 方法,複製在多個要求內大小受限的區塊中的資料。執行此操作時,必須使用迴圈並呼叫 rewrite 方法,直到所有資料移動完畢:

  1. 使用 cURL 以及 JSON API rewrite 方法,將資料從來源值區複製到目標值區,再將 [VALUES_IN_BRACKETS] 取代為適當的值:
  2. curl -X POST -H "Authorization: Bearer [OAUTH2_TOKEN]" \
    -H "Content-Length: 0" \
    "https://www.googleapis.com/storage/v1/b/[SOURCE_BUCKET]/o/[OBJECT_NAME]/rewriteTo/b/[DESTINATION_BUCKET]/o/[OBJECT_NAME]"
    

    例如,如果物件的大小為 10 GB,對此要求的回應則會類似以下範例:

    {
    "kind": "storage#rewriteResponse",
    "totalBytesRewritten": 1048576,
    "objectSize": 10000000000,
    "done": false,
    "rewriteToken": [TOKEN_VALUE]
    }
    
  3. 在後續要求中,使用 rewriteToken 繼續複製資料,將 [VALUES_IN_BRACKETS] 替換為適當的值:
  4. curl -X POST -H "Authorization: Bearer [OAUTH2_TOKEN]" \
    -H "Content-Length: 0" \
    -d '{"rewriteToken": "[TOKEN_VALUE]"}' \
    "https://www.googleapis.com/storage/v1/b/[SOURCE_BUCKET]/o/[OBJECT_NAME]/rewriteTo/b/[DESTINATION_BUCKET]/o/[OBJECT_NAME]"
    

    所有資料複製完畢後,最後一個回覆的 done 屬性會等於 true,其中沒有 rewriteToken 屬性,且複製物件的中繼資料會在 resource 屬性中。

    {
    "kind": "storage#rewriteResponse",
    "totalBytesRewritten": 10000000000,
    "objectSize": 10000000000,
    "done": true,
    "resource": objects Resource
    }
    

步驟 3) 刪除舊值區中的檔案

主控台

您無需進行任何操作來刪除舊值區中的檔案:使用移轉服務來複製檔案時,舊檔案會自動刪除 (假設有選取「轉移作業完成後刪除來源物件」核取方塊的情況下)。

gsutil

使用具有 -r 選項的 gsutil rm 指令,以遞迴方式從來源值區中刪除您所有的檔案與來源值區本身。再將 [VALUES_IN_BRACKETS] 取代為適當的值:

gsutil rm -r gs://[SOURCE_BUCKET]

如要刪除檔案但保留來源值區,請使用:

gsutil rm -a gs://[SOURCE_BUCKET]/**

REST API

JSON API

  1. 使用 cURL 與 JSON API delete 方法,運用以下指令刪除原始版本的資料,將 [VALUES_IN_BRACKETS] 取代為適當的值:
    curl -X DELETE -H "Authorization: Bearer [OAUTH2_TOKEN]" \
    https://www.googleapis.com/storage/v1/b/[SOURCE_BUCKET]/o/[OBJECT_NAME]

如果成功的話,這個方法會傳回空白的回應。

後續步驟

本頁內容對您是否有任何幫助?請提供意見:

傳送您對下列選項的寶貴意見...

這個網頁
Cloud Storage
需要協助嗎?請前往我們的支援網頁