Criar e gerenciar partições de instância

Nesta página, você vai aprender a criar e gerenciar partições de instância do Spanner.

Criar uma partição de instância

Console

  1. No console Google Cloud , abra a página Spanner.

    Acessar o Spanner

  2. Selecione a instância em que você quer adicionar partições de instância.

  3. No menu de navegação, selecione Partições de instâncias.

  4. Clique em Criar partição de instância.

  5. Insira um ID da partição de instância para identificar permanentemente a partição de instância. O ID da partição da instância também precisa ser exclusivo na instância. Não é possível mudar o ID da partição de instância depois.

  6. Na seção Escolher uma configuração, selecione Regional ou Multirregional. Se quiser comparar as especificações entre as regiões, clique em Comparar configurações de região.

  7. Selecione uma configuração no menu suspenso.

  8. Na seção Configurar capacidade de computação, em Selecionar unidade, clique em uma das seguintes opções:

    • Nós para instâncias grandes. Um nó equivale a 1.000 unidades de processamento.
    • Unidades de processamento para partições de instâncias pequenas.

    Para mais informações, consulte Capacidade de computação, nós e unidades de processamento.

  9. Em Escolher um modo de escalonamento, clique em uma das seguintes opções:

    • Alocação manual se você quiser definir manualmente a capacidade de computação para custos e recursos fixos de computação.

      • A quantidade indica o número de unidades de processamento ou nós a serem usados para essa instância.
    • Escalonamento automático para permitir que o Spanner adicione e remova automaticamente a capacidade de computação. O escalonador automático gerenciado está disponível nas edições Enterprise e Enterprise Plus do Spanner. Para mais informações sobre o escalonador automático gerenciado, consulte Escalonador automático gerenciado para Spanner. Configure as seguintes opções de autoescalonamento gerenciado:

      • Mínimo indica o limite mínimo para reduzir escala vertical, dependendo da unidade de medida escolhida para Capacidade de computação. Para mais informações, consulte Determinar o limite mínimo.
      • Máximo indica o limite máximo para escalonar, dependendo da unidade de medida escolhida para Capacidade de computação. Para mais informações, consulte Determinar o limite máximo.
      • A meta de utilização de CPU de alta prioridade indica a porcentagem de CPU a ser usada para tarefas de alta prioridade. Para mais informações, consulte Determinar a meta de uso da CPU.
      • A meta de uso total da CPU indica a porcentagem de destino da CPU a ser usada para todas as tarefas de baixa, média e alta prioridade. Para mais informações, consulte Determinar a meta de utilização total da CPU.
      • A meta de uso do armazenamento indica a porcentagem desejada de armazenamento a ser usada. Para mais informações, consulte Determinar o objetivo de uso do armazenamento.
  10. Clique em Criar para criar a partição de instância.

gcloud

Para criar uma partição de instância, use gcloud spanner instance-partitions create.

gcloud spanner instance-partitions create INSTANCE_PARTITION_ID \
  --config=INSTANCE_PARTITION_CONFIG \
  --description="INSTANCE_PARTITION_DESCRIPTION" \
  --instance=INSTANCE_ID \
  [--nodes=NODE_COUNT | --processing-units=PROCESSING_UNIT_COUNT]

Substitua:

  • INSTANCE_PARTITION_ID: o identificador permanente da partição de instância exclusivo na sua instância. Não é possível mudar o ID da partição de instância depois.
  • INSTANCE_PARTITION_CONFIG: o identificador permanente da configuração de partição da instância, que define a localização geográfica da partição e afeta onde os dados são armazenados.
  • INSTANCE_PARTITION_DESCRIPTION: o nome a ser exibido para a partição de instância no console do Google Cloud . O nome da partição da instância precisa ser exclusivo na instância.
  • INSTANCE_ID: o identificador permanente da sua instância do Spanner em que essa partição de instância reside.
  • NODE_COUNT: a capacidade de computação da partição da instância, expressa como um número de nós. Um nó equivale a 1.000 unidades de processamento.
  • PROCESSING_UNIT_COUNT: a capacidade de computação da instância, expressa como um número de unidades de processamento. Sua partição de instância precisa ter pelo menos 1.000 unidades de processamento. Insira quantidades em múltiplos de 1.000 (1.000, 2.000, 3.000 e assim por diante).

Por exemplo, para criar uma partição de instância europe-partition em eur3 com cinco nós, execute o seguinte:

  gcloud spanner instance-partitions create europe-partition --config=eur3 \
    --description="europe-partition" --instance=test-instance --nodes=5

Usar o escalonamento automático gerenciado

É possível usar o escalonamento automático gerenciado com o comando gcloud spanner instance-partitions create. Para mais informações, consulte Escalonador automático gerenciado.

Use o comando a seguir para criar uma partição de instância com escalonador automático gerenciado:

  gcloud 
  spanner instance-partitions create INSTANCE_PARTITION_ID \
    --config=INSTANCE_PARTITION_CONFIG \
    --description="INSTANCE_PARTITION_DESCRIPTION" \
    --instance=INSTANCE_ID \
    --autoscaling-min-processing-units=MINIMUM_PROCESSING_UNITS \
    --autoscaling-max-processing-units=MAXIMUM_PROCESSING_UNITS \
    --autoscaling-high-priority-cpu-target=HIGH_PRIORITY_CPU_PERCENTAGE \
    --autoscaling-total-cpu-target=TOTAL_CPU_PERCENTAGE \
    --autoscaling-storage-target=STORAGE_PERCENTAGE

ou

  gcloud spanner instance-partitions create INSTANCE_PARTITION_ID \
    --config=INSTANCE_PARTITION_CONFIG \
    --description="INSTANCE_PARTITION_DESCRIPTION" \
    --instance=INSTANCE_ID \
    --autoscaling-min-nodes=MINIMUM_NODES \
    --autoscaling-max-nodes=MAXIMUM_NODES \
    --autoscaling-high-priority-cpu-target=HIGH_PRIORITY_CPU_PERCENTAGE \
    --autoscaling-total-cpu-target=TOTAL_CPU_PERCENTAGE
    --autoscaling-storage-target=STORAGE_PERCENTAGE

Substitua:

  • INSTANCE_PARTITION_ID: o identificador permanente da partição de instância exclusivo na sua instância. Não é possível mudar o ID da partição de instância depois.
  • INSTANCE_PARTITION_CONFIG: o identificador permanente da configuração de partição da instância, que define a localização geográfica da partição e afeta onde os dados são armazenados.
  • INSTANCE_PARTITION_DESCRIPTION: o nome a ser exibido para a partição de instância no console do Google Cloud . O nome da partição da instância precisa ser exclusivo na instância.
  • INSTANCE_ID: o identificador permanente da sua instância do Spanner em que essa partição de instância reside.
  • MINIMUM_PROCESSING_UNITS ou MINIMUM_NODES: o número mínimo de unidades de processamento ou nós ao reduzir a escala. Para mais informações, consulte Determinar o limite mínimo.
  • MAXIMUM_PROCESSING_UNITS ou MAXIMUM_NODES: o número máximo de unidades de processamento ou nós ao escalonar verticalmente. Para mais informações, consulte Determinar o limite máximo.
  • HIGH_PRIORITY_CPU_PERCENTAGE: a porcentagem de meta de CPU de alta prioridade a ser usada, com base na prioridade da tarefa. A porcentagem de CPU pode variar de 10 a 90%. Para mais informações, consulte Determinar a meta de utilização de CPU de alta prioridade.
  • TOTAL_CPU_PERCENTAGE: a porcentagem desejada do total de CPU de prioridade a ser usada. A meta de CPU total precisa ser maior que a meta de CPU de alta prioridade. A porcentagem de CPU pode variar de 10 a 90%. Para mais informações, consulte Determinar a meta de utilização total da CPU.
  • STORAGE_PERCENTAGE: a porcentagem de armazenamento a ser usada, de 10 a 99%. Para mais informações, consulte Determinar o objetivo de uso do armazenamento.

Bibliotecas de cliente

C++

Para saber como instalar e usar a biblioteca de cliente do Spanner, consulte Bibliotecas de cliente do Spanner.

void CreateInstancePartition(
    google::cloud::spanner_admin::InstanceAdminClient client,
    std::string const& project_id, std::string const& instance_id,
    std::string const& instance_partition_id) {
  auto project = google::cloud::Project(project_id);
  auto in = google::cloud::spanner::Instance(project_id, instance_id);
  auto config = project.FullName() + "/instanceConfigs/nam3";

  google::spanner::admin::instance::v1::CreateInstancePartitionRequest request;
  request.set_parent(in.FullName());
  request.set_instance_partition_id(instance_partition_id);
  request.mutable_instance_partition()->set_display_name(
      "Test instance partition");
  request.mutable_instance_partition()->set_node_count(1);
  request.mutable_instance_partition()->set_config(config);

  auto instance_partition = client.CreateInstancePartition(request).get();
  if (!instance_partition) throw std::move(instance_partition).status();
  std::cout << "Created instance partition [" << instance_partition_id << "]:\n"
            << instance_partition->DebugString();
}

C#

Para saber como instalar e usar a biblioteca de cliente do Spanner, consulte Bibliotecas de cliente do Spanner.


using Google.Cloud.Spanner.Admin.Instance.V1;
using Google.Cloud.Spanner.Common.V1;
using Google.LongRunning;
using System;

public class CreateInstancePartitionSample
{
    public InstancePartition CreateInstancePartition(string projectId, string instanceId, string instancePartitionId)
    {
        // Create the InstanceAdminClient instance.
        InstanceAdminClient instanceAdminClient = InstanceAdminClient.Create();

        // Initialize request parameters.
        InstancePartition partition = new InstancePartition
        {
            DisplayName = "This is a display name.",
            NodeCount = 1,
            ConfigAsInstanceConfigName = InstanceConfigName.FromProjectInstanceConfig(projectId, "nam3"),
        };
        InstanceName instanceName = InstanceName.FromProjectInstance(projectId, instanceId);

        // Make the CreateInstancePartition request.
        Operation<InstancePartition, CreateInstancePartitionMetadata> response = instanceAdminClient.CreateInstancePartition(instanceName, partition, instancePartitionId);

        Console.WriteLine("Waiting for the operation to finish.");

        // Poll until the returned long-running operation is complete.
        Operation<InstancePartition, CreateInstancePartitionMetadata> completedResponse = response.PollUntilCompleted();

        if (completedResponse.IsFaulted)
        {
            Console.WriteLine($"Error while creating instance partition: {completedResponse.Exception}");
            throw completedResponse.Exception;
        }

        Console.WriteLine($"Instance created successfully.");

        return completedResponse.Result;
    }
}

Go

Para saber como instalar e usar a biblioteca de cliente do Spanner, consulte Bibliotecas de cliente do Spanner.

import (
	"context"
	"fmt"
	"io"

	instance "cloud.google.com/go/spanner/admin/instance/apiv1"
	"cloud.google.com/go/spanner/admin/instance/apiv1/instancepb"
)

// Example of creating an instance partition with Go.
// projectID is the ID of the project that the new instance partition will be in.
// instanceID is the ID of the instance that the new instance partition will be in.
// instancePartitionID is the ID of the new instance partition to be created.
func createInstancePartition(w io.Writer, projectID, instanceID, instancePartitionID string) error {
	// projectID := "my-project-id"
	// instanceID := "my-instance"
	// instancePartitionID := "my-instance-partition"
	ctx := context.Background()
	instanceAdmin, err := instance.NewInstanceAdminClient(ctx)
	if err != nil {
		return err
	}
	defer instanceAdmin.Close()

	op, err := instanceAdmin.CreateInstancePartition(ctx, &instancepb.CreateInstancePartitionRequest{
		Parent:              fmt.Sprintf("projects/%s/instances/%s", projectID, instanceID),
		InstancePartitionId: instancePartitionID,
		InstancePartition: &instancepb.InstancePartition{
			Config:          fmt.Sprintf("projects/%s/instanceConfigs/%s", projectID, "nam3"),
			DisplayName:     "my-instance-partition",
			ComputeCapacity: &instancepb.InstancePartition_NodeCount{NodeCount: 1},
		},
	})
	if err != nil {
		return fmt.Errorf("could not create instance partition %s: %w", fmt.Sprintf("projects/%s/instances/%s/instancePartitions/%s", projectID, instanceID, instancePartitionID), err)
	}
	// Wait for the instance partition creation to finish.
	i, err := op.Wait(ctx)
	if err != nil {
		return fmt.Errorf("waiting for instance partition creation to finish failed: %w", err)
	}
	// The instance partition may not be ready to serve yet.
	if i.State != instancepb.InstancePartition_READY {
		fmt.Fprintf(w, "instance partition state is not READY yet. Got state %v\n", i.State)
	}
	fmt.Fprintf(w, "Created instance partition [%s]\n", instancePartitionID)
	return nil
}

Java

Para saber como instalar e usar a biblioteca de cliente do Spanner, consulte Bibliotecas de cliente do Spanner.


import com.google.cloud.spanner.Spanner;
import com.google.cloud.spanner.SpannerOptions;
import com.google.cloud.spanner.admin.instance.v1.InstanceAdminClient;
import com.google.spanner.admin.instance.v1.CreateInstancePartitionRequest;
import com.google.spanner.admin.instance.v1.InstanceConfigName;
import com.google.spanner.admin.instance.v1.InstanceName;
import com.google.spanner.admin.instance.v1.InstancePartition;
import java.util.concurrent.ExecutionException;

class CreateInstancePartitionSample {

  static void createInstancePartition() {
    // TODO(developer): Replace these variables before running the sample.
    String projectId = "my-project";
    String instanceId = "my-instance";
    String instancePartitionId = "my-instance-partition";
    createInstancePartition(projectId, instanceId, instancePartitionId);
  }

  static void createInstancePartition(
      String projectId, String instanceId, String instancePartitionId) {
    // Set instance partition configuration.
    int nodeCount = 1;
    String displayName = "Descriptive name";

    // Create an InstancePartition object that will be used to create the instance partition.
    InstancePartition instancePartition =
        InstancePartition.newBuilder()
            .setDisplayName(displayName)
            .setNodeCount(nodeCount)
            .setConfig(InstanceConfigName.of(projectId, "nam3").toString())
            .build();

    try (Spanner spanner =
            SpannerOptions.newBuilder().setProjectId(projectId).build().getService();
        InstanceAdminClient instanceAdminClient = spanner.createInstanceAdminClient()) {

      // Wait for the createInstancePartition operation to finish.
      InstancePartition createdInstancePartition =
          instanceAdminClient
              .createInstancePartitionAsync(
                  CreateInstancePartitionRequest.newBuilder()
                      .setParent(InstanceName.of(projectId, instanceId).toString())
                      .setInstancePartitionId(instancePartitionId)
                      .setInstancePartition(instancePartition)
                      .build())
              .get();
      System.out.printf(
          "Instance partition %s was successfully created%n", createdInstancePartition.getName());
    } catch (ExecutionException e) {
      System.out.printf(
          "Error: Creating instance partition %s failed with error message %s%n",
          instancePartition.getName(), e.getMessage());
    } catch (InterruptedException e) {
      System.out.println(
          "Error: Waiting for createInstancePartition operation to finish was interrupted");
    }
  }
}

Node.js

Para saber como instalar e usar a biblioteca de cliente do Spanner, consulte Bibliotecas de cliente do Spanner.

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

/**
 * TODO(developer): Uncomment the following lines before running the sample.
 */
// const projectId = 'my-project-id';
// const instanceId = 'my-instance';
// const instancePartitionId = 'my-instance-partition';

// Creates a client
const spanner = new Spanner({
  projectId: projectId,
});

// Get the instance admin client
const instanceAdminClient = spanner.getInstanceAdminClient();

// Creates a new instance partition
try {
  console.log(
    `Creating instance partition ${instanceAdminClient.instancePartitionPath(
      projectId,
      instanceId,
      instancePartitionId,
    )}.`,
  );
  const [operation] = await instanceAdminClient.createInstancePartition({
    instancePartitionId: instancePartitionId,
    parent: instanceAdminClient.instancePath(projectId, instanceId),
    instancePartition: {
      config: instanceAdminClient.instanceConfigPath(projectId, 'nam3'),
      nodeCount: 1,
      displayName: 'Test instance partition',
    },
  });

  console.log(
    `Waiting for operation on ${instancePartitionId} to complete...`,
  );
  await operation.promise();

  console.log(`Created instance partition ${instancePartitionId}.`);
} catch (err) {
  console.error('ERROR:', err);
}

PHP

Para saber como instalar e usar a biblioteca de cliente do Spanner, consulte Bibliotecas de cliente do Spanner.

use Google\Cloud\Spanner\Admin\Instance\V1\Client\InstanceAdminClient;
use Google\Cloud\Spanner\Admin\Instance\V1\CreateInstancePartitionRequest;
use Google\Cloud\Spanner\Admin\Instance\V1\InstancePartition;

/**
 * Creates an instance partition.
 * Example:
 * ```
 * create_instance_partition($projectId, $instanceId, $instancePartitionId);
 * ```
 *
 * @param string $projectId The Google Cloud project ID.
 * @param string $instanceId The Spanner instance ID.
 * @param string $instancePartitionId The instance partition ID.
 */
function create_instance_partition(string $projectId, string $instanceId, string $instancePartitionId): void
{
    $instanceAdminClient = new InstanceAdminClient();

    $instanceName = $instanceAdminClient->instanceName($projectId, $instanceId);
    $instancePartitionName = $instanceAdminClient->instancePartitionName($projectId, $instanceId, $instancePartitionId);
    $configName = $instanceAdminClient->instanceConfigName($projectId, 'nam3');

    $instancePartition = (new InstancePartition())
        ->setConfig($configName)
        ->setDisplayName('Test instance partition.')
        ->setNodeCount(1);

    $operation = $instanceAdminClient->createInstancePartition(
        (new CreateInstancePartitionRequest())
        ->setParent($instanceName)
        ->setInstancePartitionId($instancePartitionId)
        ->setInstancePartition($instancePartition)
    );

    print('Waiting for operation to complete...' . PHP_EOL);
    $operation->pollUntilComplete();

    printf('Created instance partition %s' . PHP_EOL, $instancePartitionId);
}

Python

Para saber como instalar e usar a biblioteca de cliente do Spanner, consulte Bibliotecas de cliente do Spanner.

def create_instance_partition(instance_id, instance_partition_id):
    """Creates an instance partition."""
    from google.cloud.spanner_admin_instance_v1.types import spanner_instance_admin

    spanner_client = spanner.Client()
    instance_admin_api = spanner_client.instance_admin_api

    config_name = "{}/instanceConfigs/nam3".format(spanner_client.project_name)

    operation = spanner_client.instance_admin_api.create_instance_partition(
        parent=instance_admin_api.instance_path(spanner_client.project, instance_id),
        instance_partition_id=instance_partition_id,
        instance_partition=spanner_instance_admin.InstancePartition(
            config=config_name,
            display_name="Test instance partition",
            node_count=1,
        ),
    )

    print("Waiting for operation to complete...")
    operation.result(OPERATION_TIMEOUT_SECONDS)

    print("Created instance partition {}".format(instance_partition_id))

Descrever uma partição de instância

gcloud

Para descrever uma partição de instância, use gcloud spanner instance-partitions describe.

gcloud spanner instance-partitions describe PARTITION_ID \
  --instance=INSTANCE_ID

Substitua:

  • INSTANCE_PARTITION_ID: identificador permanente da partição da instância.
  • INSTANCE_ID: identificador permanente da instância.

Por exemplo, para descrever a partição de instância europe-partition, execute o seguinte:

  gcloud spanner instance-partitions describe europe-partition
    --instance=test-instance

Listar partições de instância

Console

  1. No console Google Cloud , abra a página Spanner.

    Acessar o Spanner

  2. Selecione uma instância na lista.

  3. No menu de navegação, selecione Partições de instâncias.

    Uma lista de partições de instância associadas a essa instância é mostrada.

gcloud

Para listar as partições de instância, use gcloud spanner instance-partitions list.

gcloud spanner instance-partitions list --instance=INSTANCE_ID

A CLI gcloud imprime uma lista das partições de instância do Spanner, além do ID, nome de exibição, configuração e capacidade de computação de cada uma delas.

Editar uma partição de instância

A seção a seguir explica como mudar a capacidade de computação da partição de instância. Não é possível mudar o ID, o nome ou a configuração da partição da instância.

Mudar a capacidade de computação

Provisione capacidade de computação suficiente para manter a utilização da CPU e a utilização de armazenamento abaixo dos valores máximos recomendados. Para mais informações, consulte as cotas e limites do Spanner.

Se você quiser aumentar a capacidade de computação de uma partição de instância, seu projetoGoogle Cloud precisa ter cota suficiente para adicionar a capacidade de computação. O tempo necessário para concluir o pedido de aumento depende do tamanho da solicitação. Na maioria dos casos, as solicitações são concluídas em alguns minutos. Em raras ocasiões, um escalonar verticalmente pode levar até uma hora para ser concluído.

Console

  1. No console Google Cloud , abra a página Spanner.

    Acessar o Spanner

  2. Selecione uma instância na lista.

  3. No menu de navegação, selecione Partições de instâncias.

  4. Na lista de partições de instância, na coluna Ações, clique em Mais ações e selecione Editar.

  5. Para mudar a capacidade de computação, escolha uma unidade de medida (unidades de processamento ou nós) e insira uma quantidade. Ao usar unidades de processamento, insira quantidades em múltiplos de 1.000 (1.000, 2.000, 3.000 e assim por diante). Cada nó é igual a 1.000 unidades de processamento.

    Sua partição de instância precisa ter pelo menos um nó (1.000 unidades de processamento).

  6. Clique em Salvar.

    Se for exibida uma caixa de diálogo informando que sua cota é insuficiente para adicionar capacidade de computação , siga as instruções para solicitar uma cota maior.

gcloud

Para mudar a capacidade de computação da partição de instância, use gcloud spanner instance-partitions update. Ao usar esse comando, especifique a capacidade de computação como um número de nós ou unidades de processamento.

gcloud spanner instance-partitions update INSTANCE_PARTITION_ID \
  --instance=INSTANCE_ID \
  [--nodes=NODE_COUNT | --processing-units=PROCESSING_UNIT_COUNT]
  [--async]

Substitua:

  • INSTANCE_PARTITION_ID: identificador permanente da partição da instância.
  • INSTANCE_ID: identificador permanente da instância.
  • NODE_COUNT: a nova capacidade de computação da partição da instância, expressa como um número de nós. Um nó equivale a 1.000 unidades de processamento.
  • PROCESSING_UNIT_COUNT: a nova capacidade de computação da partição de instância, expressa como um número de unidades de processamento. Sua partição de instância precisa ter pelo menos 1.000 unidades de processamento. Insira quantidades em múltiplos de 1.000 (1.000, 2.000, 3.000 e assim por diante).

Sinalizações opcionais:

  • --async: use essa flag se quiser que sua solicitação retorne imediatamente, sem aguardar a conclusão da operação.

Para verificar o status da sua solicitação, execute gcloud spanner operations describe.

Ativar ou modificar o escalonador automático gerenciado em uma partição de instância

As limitações a seguir se aplicam quando você ativa ou muda o recurso de escalonamento automático gerenciado em uma partição de instância atual:

  • Não é possível mover uma instância enquanto o escalonador automático gerenciado estiver ativado.

Console

  1. No console Google Cloud , abra a página Spanner.

    Acessar o Spanner

  2. Selecione uma instância na lista.

  3. No menu de navegação, selecione Partições de instâncias.

  4. Na lista de partições de instância, na coluna Ações, clique em Mais ações e selecione Editar.

  5. Em Configurar capacidade de computação, clique em Escalonamento automático.

  6. Em Mínimo, selecione o limite mínimo a ser usado ao reduzir a escala. Para mais informações, consulte Determinar o limite mínimo.

  7. Em Máximo, selecione o limite máximo a ser usado ao fazer o escalonamento vertical. Para mais informações, consulte Determinar o limite máximo.

  8. Em Meta de utilização de CPU de alta prioridade, insira a porcentagem de CPU a ser usada para tarefas de alta prioridade. Para mais informações, consulte Determinar a meta de utilização da CPU.

  9. Em Meta de utilização total da CPU, insira a porcentagem de CPU de destino a ser usada para todas as tarefas de baixa, média e alta prioridade. A porcentagem de CPU pode variar de 10 a 90%. Para mais informações, consulte Determinar a meta de utilização total da CPU.

  10. Em Meta de uso do armazenamento, insira a porcentagem de armazenamento a ser usada. Para mais informações, consulte Determinar o objetivo de uso do armazenamento.

  11. Clique em Salvar.

gcloud

Use o comando gcloud spanner instance-partitions update para ativar o escalonador automático gerenciado em uma partição de instância. Para mais informações e limitações, consulte Flags e limitações do Google Cloud CLI.

É possível adicionar o escalonador automático gerenciado com o seguinte comando:

  gcloud spanner instance-partitions update INSTANCE_PARTITION_ID \
    --instance=INSTANCE_ID \
    --autoscaling-min-processing-units=MINIMUM_PROCESSING_UNITS \
    --autoscaling-max-processing-units=MAXIMUM_PROCESSING_UNITS \
    --autoscaling-high-priority-cpu-target=HIGH_PRIORITY_CPU_PERCENTAGE \
    --autoscaling-total-cpu-target=TOTAL_CPU_PERCENTAGE \
    --autoscaling-storage-target=STORAGE_PERCENTAGE

ou

  gcloud spanner instance-partitions update INSTANCE_PARTITION_ID \
    --instance=INSTANCE_ID \
    --autoscaling-min-nodes=MINIMUM_NODES \
    --autoscaling-max-nodes=MAXIMUM_NODES \
    --autoscaling-high-priority-cpu-target=HIGH_PRIORITY_CPU_PERCENTAGE \
    --autoscaling-total-cpu-target=TOTAL_CPU_PERCENTAGE \
    --autoscaling-storage-target=STORAGE_PERCENTAGE

Substitua:

  • INSTANCE_PARTITION_ID: identificador permanente da partição da instância.
  • INSTANCE_ID: identificador permanente da instância.
  • MINIMUM_PROCESSING_UNITS ou MINIMUM_NODES: o número mínimo de unidades de processamento ou nós a serem usados ao reduzir a escala. Para mais informações, consulte Determinar o limite mínimo.
  • MAXIMUM_PROCESSING_UNITS ou MAXIMUM_NODES: o número máximo de unidades de processamento ou nós a serem usados ao fazer o escalonamento vertical. Para mais informações, consulte Determinar o limite máximo.
  • HIGH_PRIORITY_CPU_PERCENTAGE: a porcentagem de meta de CPU de alta prioridade a ser usada, com base na prioridade da tarefa. A porcentagem de CPU pode variar de 10 a 90%. Para mais informações, consulte Determinar a meta de utilização de CPU de alta prioridade.
  • TOTAL_CPU_PERCENTAGE: a porcentagem desejada do total de CPU de prioridade a ser usada. A meta de CPU total precisa ser maior que a meta de CPU de alta prioridade. A porcentagem de CPU pode variar de 10 a 90%. Para mais informações, consulte Determinar a meta de utilização total da CPU.
  • STORAGE_PERCENTAGE: a porcentagem de armazenamento a ser usada, de 10% a 99%. Para mais informações, consulte Determinar o objetivo de uso do armazenamento.

Depois de ativar o autoescalador gerenciado em uma partição de instância, você também pode modificar as configurações dele. Por exemplo, se você quiser aumentar o número máximo de unidades de processamento para 10.000, execute o seguinte comando:

gcloud spanner instance-partitions update test-instance-partition \
     --instance=test-instance
     --autoscaling-max-processing-units=10000

Mudar uma partição de instância do uso do escalonador automático gerenciado para o escalonamento manual

Console

  1. Acesse a página Instâncias do Spanner no console do Google Cloud .

    Acessar a página "Instâncias"

  2. Selecione uma instância na lista.

  3. No menu de navegação, selecione Partições de instâncias.

  4. Na lista de partições de instância, na coluna Ações, clique em Mais ações e selecione Editar.

  5. Em Escolher um modo de escalonamento, marque a caixa Alocação manual.

  6. Clique em Salvar.

gcloud

Use o comando gcloud spanner instance-partitions update para atualizar a partição da instância.

Use o comando a seguir para mudar uma partição de instância do uso do escalonador automático gerenciado para o escalonamento manual:

  gcloud spanner instance-partitions update INSTANCE_PARTITION_ID \
    --instance=INSTANCE_ID \
  --processing-units=PROCESSING_UNIT_COUNT

ou

  gcloud spanner instance-partitions update INSTANCE_PARTITION_ID \
    --instance=INSTANCE_ID \
  --nodes=NODE_COUNT

Substitua:

  • INSTANCE_PARTITION_ID: identificador permanente da partição da instância.
  • INSTANCE_ID: identificador permanente da instância.
  • NODE_COUNT: a capacidade de computação da instância, expressa como um número de nós. Cada nó é igual a 1.000 unidades de processamento.
  • PROCESSING_UNIT_COUNT: a capacidade de computação da instância, expressa como um número de unidades de processamento. O mínimo de unidades de processamento para uma partição de instância é 1.000.

Excluir uma partição de instância

Não é possível excluir uma partição de instância enquanto ela estiver associada a posicionamentos ou dados. Primeiro, mova os dados que estão na partição da instância ou exclua as tabelas de posicionamento que usam a partição da instância antes de excluir a partição.

Console

  1. No console Google Cloud , abra a página Spanner.

    Acessar o Spanner

  2. Selecione uma instância na lista.

  3. No menu de navegação, selecione Partições de instâncias.

  4. Na lista de partições de instância, na coluna Ações, clique em Mais ações e selecione Excluir.

  5. Siga as instruções para confirmar a exclusão da partição da instância.

  6. Clique em Excluir.

gcloud

Use o comando gcloud spanner instance-partitions delete.

gcloud spanner instance-partitions delete INSTANCE_PARTITION_ID
  --instance=INSTANCE_ID

A seguir