建立儲存空間值區

本頁說明如何建立 Cloud Storage 值區。如需值區總覽,請參閱重要詞彙。如果未在要求中特別指定,則系統會在 us 多地區位置建立值區,且預設的儲存空間級別為 Standard Storage

如要建立新的儲存空間值區:

主控台

  1. 在 Google Cloud Platform Console 中開啟 Cloud Storage 瀏覽器。
    開啟 Cloud Storage 瀏覽器
  2. 按一下 [Create bucket] (建立值區) 以開啟值區建立表單。
  3. 新的值區。

  4. 輸入值區資訊,然後按一下 [Continue] (繼續) 以完成每個步驟:
    • 指定 [Name] (名稱),名稱必須遵守值區命名規定
    • 選取值區的 [Default storage class] (預設儲存空間級別)。根據預設,系統會指派預設的儲存空間級別給所有上傳到值區的物件。接下來,選擇要永久儲存值區資料的 [Location] (位置)

      注意:右側窗格中的 [Monthly cost estimate] (每月預估費用) 面板會根據您所選的儲存空間級別和位置,以及預期的資料大小和作業,估算值區的每月費用。

    • 請選取一種 [Access control model](存取權控管模型),決定值區物件的存取控管方式
    • (選用)您可以新增 Bucket 標籤、設定保留政策,以及選擇加密方式
  5. 按一下 [Done] (完成)

gsutil

使用 gsutil mb 指令:

gsutil mb gs://[BUCKET_NAME]/

其中:

  • [BUCKET_NAME] 是您要授予值區的名稱,必須遵守命名要求。例如 my-bucket

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

  • -p:指定要與您的值區建立關聯的專案。例如 my-project
  • -c:指定值區的預設儲存空間級別。例如 nearline
  • -l:指定值區的位置。例如 us-east1
  • -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.
 *
 */
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 檔案:
  3. {
      "name": "[BUCKET_NAME]",
      "location": "[BUCKET_LOCATION]",
      "storageClass": "[STORAGE_CLASS]"
    }

    其中:

    • [BUCKET_NAME] 是您要授予值區的名稱,必須遵守命名要求。例如 my-bucket
    • [BUCKET_LOCATION] 是您希望儲存值區物件資料位置。例如 us-east1
    • [STORAGE_CLASS] 是值區的預設儲存空間級別。例如 nearline
  4. 使用 cURL 呼叫 JSON API
    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]"

    其中:

    • [JSON_FILE_NAME] 是您在步驟 2 建立的 JSON 檔案名稱。
    • [OAUTH2_TOKEN] 是您在步驟 1 中產生的存取憑證。
    • [PROJECT_ID] 是要與您的值區建立關聯的專案 ID。例如 my-project

XML API

  1. OAuth 2.0 Playground 取得授權存取憑證。將 Playground 設為使用自己的 OAuth 憑證。
  2. 建立包含下列資訊的 .xml 檔案:
  3. <CreateBucketConfiguration>
       <LocationConstraint>[BUCKET_LOCATION]</LocationConstraint>
       <StorageClass>[STORAGE_CLASS]</StorageClass>
    </CreateBucketConfiguration>

    其中:

  4. 使用 cURL 呼叫 XML API
    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]"

    其中:

    • [XML_FILE_NAME] 是您在步驟 2 建立的 XML 檔案名稱。
    • [OAUTH2_TOKEN] 是您在步驟 1 中產生的存取憑證。
    • [PROJECT_ID] 是要與您的值區建立關聯的專案 ID。例如 my-project
    • [BUCKET_NAME] 是您要授予值區的名稱,必須遵守命名要求。例如 my-bucket

後續步驟

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

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

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