Usa etiquetas de depósito

En esta página, se muestra cómo agregar, ver, editar y quitar las etiquetas configuradas en un depósito de Cloud Storage. Para obtener una descripción general los depósitos y de sus etiquetas, consulta Términos clave.

Agrega una etiqueta de depósito

Console

  1. Abre el navegador de Cloud Storage en Google Cloud Console.
    Abrir el navegador de Cloud Storage
  2. En la lista de depósitos, busca el depósito al que deseas aplicar una etiqueta y haz clic en el botón más opciones (tres puntos verticales).

  3. Haz clic en Editar etiquetas.

  4. En el panel lateral que aparece, haz clic en el botón + Agregar etiqueta.

  5. Especifica un key y value para tu etiqueta.

  6. Haz clic en Guardar.

En el panel lateral Editar etiquetas, también puedes editar el Valor de las etiquetas existentes.

gsutil

Usa la marca -l en un comando label ch. Por ejemplo:

gsutil label ch -l [KEY_1]:[VALUE_1] gs://[BUCKET_NAME]/

En el que:

  • [KEY_1] es el nombre de la clave de tu etiqueta. Por ejemplo, pet.
  • [VALUE_1] es el valor de tu etiqueta. Por ejemplo, dog.
  • [BUCKET_NAME] es el nombre del depósito al que se aplica la etiqueta. Por ejemplo, my-bucket.

Usa varias marcas -l para agregar o editar múltiples pares key:value en un solo comando.

Use el comando label set para reemplazar todas las etiquetas existentes por etiquetas nuevas.

Ejemplos de código

C++

Si deseas obtener más información, consulta la documentación de referencia de la API de Cloud Storage para C++.

namespace gcs = google::cloud::storage;
using ::google::cloud::StatusOr;
[](gcs::Client client, std::string bucket_name, std::string label_key,
   std::string label_value) {
  StatusOr<gcs::BucketMetadata> updated_metadata = client.PatchBucket(
      bucket_name,
      gcs::BucketMetadataPatchBuilder().SetLabel(label_key, label_value));

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

  std::cout << "Successfully set label " << label_key << " to " << label_value
            << " on bucket  " << updated_metadata->name() << ".";
  std::cout << " The bucket labels are now:";
  for (auto const& kv : updated_metadata->labels()) {
    std::cout << "\n  " << kv.first << ": " << kv.second;
  }
  std::cout << "\n";
}

PHP

Si deseas obtener más información, consulta la documentación de referencia de la API de Cloud Storage para PHP.

use Google\Cloud\Storage\StorageClient;

/**
 * Adds or updates a bucket label.
 *
 * @param string $bucketName the name of your Cloud Storage bucket.
 * @param string $labelName the name of the label to add.
 * @param string $labelValue the value of the label to add.
 */
function add_bucket_label($bucketName, $labelName, $labelValue)
{
    $storage = new StorageClient();
    $bucket = $storage->bucket($bucketName);
    $newLabels = [$labelName => $labelValue];
    $bucket->update(['labels' => $newLabels]);
    printf('Added label %s (%s) to %s' . PHP_EOL, $labelName, $labelValue, $bucketName);
}

Python

Si deseas obtener más información, consulta la documentación de referencia de la API de Cloud Storage para Python.

def add_bucket_label(bucket_name):
    """Add a label to a bucket."""
    storage_client = storage.Client()
    bucket = storage_client.get_bucket(bucket_name)

    labels = bucket.labels
    labels['example'] = 'label'
    bucket.labels = labels
    bucket.patch()

    print('Updated labels on {}.'.format(bucket.name))
    pprint.pprint(bucket.labels)

Ruby

Si deseas obtener más información, consulta la documentación de referencia de la API de Cloud Storage para Ruby.

# project_id  = "Your Google Cloud project ID"
# bucket_name = "Name of your Google Cloud Storage bucket"
# label_key   = "Cloud Storage bucket Label Key"
# label_value = "Cloud Storage bucket Label Value"

require "google/cloud/storage"

storage = Google::Cloud::Storage.new project_id: project_id
bucket  = storage.bucket bucket_name

bucket.update do |bucket|
  bucket.labels[label_key] = label_value
end

puts "Added label #{label_key} with value #{label_value} to #{bucket_name}"

API de REST

API de JSON

  1. Obtén un token de autorización de acceso de OAuth 2.0 Playground. Configura Playground para usar tus credenciales de OAuth.
  2. Crea un archivo .json que contenga la siguiente información:

    {
      "labels": {
        "[KEY_1]": "[VALUE_1]"
      }
    }

    En el que:

    • [KEY_1] es el nombre de la clave de tu etiqueta. Por ejemplo, pet.
    • [VALUE_1] es el valor de tu etiqueta. Por ejemplo, dog.
  3. Usa cURL para llamar a la API de JSON con una solicitud de depósito PATCH:

    curl -X PATCH --data-binary @[JSON_FILE_NAME].json \
      -H "Authorization: Bearer [OAUTH2_TOKEN]" \
      -H "Content-Type: application/json" \
      "https://storage.googleapis.com/storage/v1/b/[BUCKET_NAME]?fields=labels"

    En la que:

    • [JSON_FILE_NAME] es el nombre del archivo JSON que creaste en el paso 2.
    • [OAUTH2_TOKEN] es el token de acceso que generaste en el Paso 1.
    • [BUCKET_NAME] es el nombre del depósito al que se aplica la etiqueta. Por ejemplo, my-bucket.

Puede agregar o editar varios pares key:value en una solicitud.

API de XML

  1. Obtén un token de autorización de acceso de OAuth 2.0 Playground. Configura Playground para usar tus credenciales de OAuth.
  2. Crea un archivo .xml que contenga la siguiente información:

    <Tagging>
      <TagSet>
        <Tag>
          <Key>[KEY_1]</Key>
          <Value>[VALUE_1]</Value>
        </Tag>
      </TagSet>
    </Tagging>

    En la que:

    • [KEY_1] es el nombre de la clave de tu etiqueta. Por ejemplo, pet.
    • [VALUE_1] es el valor de tu etiqueta. Por ejemplo, dog.

    Ten en cuenta que puedes agregar varios elementos <Tag> en una solicitud.

  3. Usa cURL para llamar a la API de XML con una solicitud de depósito PUT y el parámetro de string de consulta tagging:

    curl -X PUT --data-binary @[XML_FILE_NAME].xml \
      -H "Authorization: Bearer [OAUTH2_TOKEN]" \
      "https://storage.googleapis.com/[BUCKET_NAME]?tagging"

    En la que:

    • [XML_FILE_NAME] es el archivo XML que creaste en el Paso 2.
    • [OAUTH2_TOKEN] es el token de acceso que generaste en el Paso 1.
    • [BUCKET_NAME] es el nombre del depósito al que se aplica la etiqueta. Por ejemplo, my-bucket.

Ve las etiquetas del depósito

Console

  1. Abre el navegador de Cloud Storage en Google Cloud Console.
    Abrir el navegador de Cloud Storage
  2. (Opcional) Puedes limitar las columnas que aparecen en la lista de depósitos de Cloud Console. Para ello, haz clic en el ícono Opciones de visualización de columnas (Ícono de opciones de la columna.).

  3. En la lista de depósitos, busca el depósito que deseas verificar y corrobora la entrada para Etiqueta. Es posible que debas desplazarte horizontalmente para ver la columna Etiqueta.

    Si tu depósito tiene varias etiquetas, algunas pueden estar ocultas. Cuando las etiquetas están ocultas, aparece un botón expandible. Si haces clic en el botón, se muestran todas las etiquetas de un depósito.

    Lista de categorías con columna de etiquetas

gsutil

Usa el siguiente comando de gsutil ls:

gsutil ls -L -b gs://[BUCKET_NAME]/

En el que:

  • [BUCKET_NAME] es el depósito cuyas etiquetas deseas ver. Por ejemplo, my-bucket.

La respuesta se ve como el siguiente ejemplo:

gs://[BUCKET_NAME]/ :
  Storage class:         STANDARD
  ...
  ...
  Labels:
    {
      "your_label_key": "your_label_value"
    }
  ...

Ejemplos de código

C++

Si deseas obtener más información, consulta la documentación de referencia de la API de Cloud Storage para C++.

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

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

  if (bucket_metadata->labels().empty()) {
    std::cout << "The bucket " << bucket_name << " has no labels set.\n";
    return;
  }

  std::cout << "The labels for bucket " << bucket_name << " are:";
  for (auto const& kv : bucket_metadata->labels()) {
    std::cout << "\n  " << kv.first << ": " << kv.second;
  }
  std::cout << "\n";
}

PHP

Si deseas obtener más información, consulta la documentación de referencia de la API de Cloud Storage para PHP.

use Google\Cloud\Storage\StorageClient;

/**
 * Prints a list of a bucket's lables.
 *
 * @param string $bucketName the name of your Cloud Storage bucket.
 */
function get_bucket_labels($bucketName)
{
    $storage = new StorageClient();
    $bucket = $storage->bucket($bucketName);
    $info = $bucket->info();
    if (isset($info['labels'])) {
        foreach ($info['labels'] as $labelKey => $labelValue) {
            printf('%s: %s' . PHP_EOL, $labelKey, $labelValue);
        }
    }
}

Python

Si deseas obtener más información, consulta la documentación de referencia de la API de Cloud Storage para Python.

def get_bucket_labels(bucket_name):
    """Prints out a bucket's labels."""
    storage_client = storage.Client()
    bucket = storage_client.get_bucket(bucket_name)
    labels = bucket.labels
    pprint.pprint(labels)

Ruby

Si deseas obtener más información, consulta la documentación de referencia de la API de Cloud Storage para Ruby.

# project_id  = "Your Google Cloud project ID"
# bucket_name = "Name of your Google Cloud Storage bucket"

require "google/cloud/storage"

storage = Google::Cloud::Storage.new project_id: project_id
bucket  = storage.bucket bucket_name

puts "Labels for #{bucket_name}"
bucket.labels.each do |key, value|
  puts "#{key} = #{value}"
end

API de REST

API de JSON

  1. Obtén un token de autorización de acceso de OAuth 2.0 Playground. Configura Playground para usar tus credenciales de OAuth.
  2. Usa cURL para llamar a la API de JSON con una solicitud de depósito GET que incluya un parámetro de string de consulta fields=labels:

    curl -X GET \
      -H "Authorization: Bearer [OAUTH2_TOKEN]" \
      "https://storage.googleapis.com/storage/v1/b/[BUCKET_NAME]?fields=labels"

    En la que:

    • [OAUTH2_TOKEN] es el token de acceso que generaste en el Paso 1.
    • [BUCKET_NAME] es el nombre del depósito cuyas etiquetas deseas ver. Por ejemplo, my-bucket.

La respuesta se ve como el siguiente ejemplo:

{
  "labels" : {
     ([YOUR_LABEL_KEY]): [YOUR_LABEL_VALUE]
   },
}

API de XML

  1. Obtén un token de autorización de acceso de OAuth 2.0 Playground. Configura Playground para usar tus credenciales de OAuth.
  2. Usa cURL para llamar a la API de XML con una solicitud de depósito GET y el parámetro de string de consulta tagging:

    curl -X GET \
      -H "Authorization: Bearer [OAUTH2_TOKEN]" \
      "https://storage.googleapis.com/[BUCKET_NAME]?tagging"

    En la que:

    • [OAUTH2_TOKEN] es el token de acceso que generaste en el Paso 1.
    • [BUCKET_NAME] es el nombre del depósito cuyas etiquetas deseas ver. Por ejemplo, my-bucket.

La respuesta se ve como el siguiente ejemplo:

<Tagging>
  <TagSet>
    <Tag>
      <Key>[YOUR_LABEL_KEY]</Key>
      <Value>[YOUR_LABEL_VALUE]</Value>
    </Tag>
  </TagSet>
</Tagging>

Quita una etiqueta de depósito

Console

  1. Abre el navegador de Cloud Storage en Google Cloud Console.
    Abrir el navegador de Cloud Storage
  2. En la lista de depósitos, busca el depósito cuya etiqueta deseas quitar y haz clic en el botón más opciones del depósito (tres puntos en vertical).

  3. Haz clic en Editar etiquetas.

  4. Haz clic en la X asociada a la etiqueta que deseas quitar.

  5. Haz clic en Guardar.

gsutil

Usa la marca -d en un comando label ch. Por ejemplo:

gsutil label ch -d [KEY_1] gs://[BUCKET_NAME]/

En el que:

  • [KEY_1] es el nombre de la clave de tu etiqueta. Por ejemplo, pet.
  • [BUCKET_NAME] es el nombre del depósito al que se aplica la etiqueta. Por ejemplo, my-bucket.

Use el comando label set para reemplazar todas las etiquetas existentes por etiquetas nuevas.

Ejemplos de código

C++

Si deseas obtener más información, consulta la documentación de referencia de la API de Cloud Storage para C++.

namespace gcs = google::cloud::storage;
using ::google::cloud::StatusOr;
[](gcs::Client client, std::string bucket_name, std::string label_key) {
  StatusOr<gcs::BucketMetadata> updated_metadata = client.PatchBucket(
      bucket_name, gcs::BucketMetadataPatchBuilder().ResetLabel(label_key));

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

  std::cout << "Successfully reset label " << label_key << " on bucket  "
            << updated_metadata->name() << ".";
  if (updated_metadata->labels().empty()) {
    std::cout << " The bucket now has no labels.\n";
    return;
  }
  std::cout << " The bucket labels are now:";
  for (auto const& kv : updated_metadata->labels()) {
    std::cout << "\n  " << kv.first << ": " << kv.second;
  }
  std::cout << "\n";
}

PHP

Si deseas obtener más información, consulta la documentación de referencia de la API de Cloud Storage para PHP.

use Google\Cloud\Storage\StorageClient;

/**
 * Removes a label from a bucket.
 *
 * @param string $bucketName the name of your Cloud Storage bucket.
 * @param string $labelName the name of the label to remove.
 */
function remove_bucket_label($bucketName, $labelName)
{
    $storage = new StorageClient();
    $bucket = $storage->bucket($bucketName);
    $labels = [$labelName => null];
    $bucket->update(['labels' => $labels]);
    printf('Removed label %s from %s' . PHP_EOL, $labelName, $bucketName);
}

Python

Si deseas obtener más información, consulta la documentación de referencia de la API de Cloud Storage para Python.

def remove_bucket_label(bucket_name):
    """Remove a label from a bucket."""
    storage_client = storage.Client()
    bucket = storage_client.get_bucket(bucket_name)

    labels = bucket.labels

    if 'example' in labels:
        del labels['example']

    bucket.labels = labels
    bucket.patch()

    print('Removed labels on {}.'.format(bucket.name))
    pprint.pprint(bucket.labels)

Ruby

Si deseas obtener más información, consulta la documentación de referencia de la API de Cloud Storage para Ruby.

# project_id  = "Your Google Cloud project ID"
# bucket_name = "Name of your Google Cloud Storage bucket"
# label_key   = "Cloud Storage bucket Label Key"

require "google/cloud/storage"

storage = Google::Cloud::Storage.new project_id: project_id
bucket  = storage.bucket bucket_name

bucket.update do |bucket|
  bucket.labels[label_key] = nil
end

puts "Deleted label #{label_key} from #{bucket_name}"

API de REST

API de JSON

  1. Obtén un token de autorización de acceso de OAuth 2.0 Playground. Configura Playground para usar tus credenciales de OAuth.
  2. Crea un archivo .json que contenga la siguiente información:

    {
      "labels": {
        "[KEY_1]": null
      }
    }

    En la que:

    • [KEY_1] es el nombre de la clave de tu etiqueta. Por ejemplo, pet.
  3. Usa cURL para llamar a la API de JSON con una solicitud de depósito PATCH:

    curl -X PATCH --data-binary @[JSON_FILE_NAME].json \
      -H "Authorization: Bearer [OAUTH2_TOKEN]" \
      -H "Content-Type: application/json" \
      "https://storage.googleapis.com/storage/v1/b/[BUCKET_NAME]?fields=labels"

    En la que:

    • [JSON_FILE_NAME] es el nombre del archivo de JSON que creaste en el Paso 2.
    • [OAUTH2_TOKEN] es el nombre del token de acceso que generaste en el Paso 1.
    • [BUCKET_NAME] es el nombre del depósito al que se aplica la etiqueta. Por ejemplo, my-bucket.

Puedes quitar varios pares key:value en una solicitud.

API de XML

  1. Obtén un token de autorización de acceso de OAuth 2.0 Playground. Configura Playground para usar tus credenciales de OAuth.
  2. Crea un archivo .xml que contenga la siguiente información:

    <Tagging>
      <TagSet>
        <Tag>
        </Tag>
      </TagSet>
    </Tagging>

    Ten en cuenta que puedes agregar varios elementos <Tag> en una solicitud.

  3. Usa cURL para llamar a la API de XML con una solicitud de depósito PUT y el parámetro de string de consulta tagging:

    curl -X PUT --data-binary @[XML_FILE_NAME].xml \
      -H "Authorization: Bearer [OAUTH2_TOKEN]" \
      "https://storage.googleapis.com/[BUCKET_NAME]?tagging"

    En la que:

    • [XML_FILE_NAME] es el nombre del archivo XML que creaste en el Paso 2.
    • [OAUTH2_TOKEN] es el nombre del token de acceso que generaste en el Paso 1.
    • [BUCKET_NAME] es el nombre del depósito al que se aplica la etiqueta. Por ejemplo, my-bucket.

Próximos pasos