Configurações regionais e multirregionais

Nesta página, descrevemos as configurações de instância e os dois tipos de configuração de instância que o Spanner oferece: configurações regionais e multirregionais. Ele também descreve as diferenças e desvantagens entre configurações regionais e multirregionais.

Configurações da instância

A configuração de uma instância define a localização geográfica e a replicação dos bancos de dados nessa instância. Ao criar uma instância, você precisa configurá-la como regional (todos os recursos estão contidos em uma única região do Google Cloud) ou multirregional (os recursos abrangem mais de uma região). Essa escolha é feita selecionando a configuração de uma instância, que determina onde seus dados serão armazenados para essa instância.

As configurações de instância com regiões fixas e topologias de replicação são chamadas de configurações de instância base. É possível criar configurações de instância personalizadas e adicionar mais réplicas somente leitura opcionais. Não é possível alterar a topologia de replicação das configurações da instância base. Para mais informações, consulte Réplicas somente leitura.

É possível mover sua instância de qualquer configuração de instância para qualquer outra configuração de instância regional ou multirregional (por exemplo, de us-centra1 para nam3).Também é possível criar uma nova configuração de instância personalizada com réplicas extras e movê-la para a nova configuração de instância personalizada. Por exemplo, se a instância estiver em us-central1 e você quiser adicionar uma réplica somente leitura us-west1, será necessário criar uma nova configuração de instância personalizada com us-central1 como a configuração básica e adicionar us-west1 como uma réplica somente leitura. Em seguida, mova a instância para a nova configuração personalizada.

Configurações regionais

Os serviços do Google Cloud estão disponíveis em locais da América do Norte, América do Sul, Europa, Ásia e Austrália. Se os seus usuários e serviços estão localizados em uma única região, escolha uma configuração de instância regional para ter leituras e gravações com a menor latência.

Para qualquer configuração regional básica, o Spanner mantém três réplicas de leitura/gravação, cada uma dentro de uma zona diferente do Google Cloud nessa região. Cada réplica de leitura/gravação contém uma cópia completa do seu banco de dados operacional que pode atender a solicitações de leitura/gravação e somente leitura. O Spanner usa réplicas em diferentes zonas para que, se ocorrer uma falha em uma única zona, o banco de dados permaneça disponível.

Configurações disponíveis

O Spanner oferece as seguintes configurações básicas de instância regional:

Nome da configuração básica Descrição do local regional Região opcional
América
northamerica-northeast1 Montreal ícone de folha Baixa emissão de carbono
northamerica-northeast2 Toronto ícone de folha Baixa emissão de carbono
southamerica-east1 São Paulo ícone de folha Baixa emissão de carbono
southamerica-west1 Santiago ícone de folha Baixa emissão de carbono
us-central1 Iowa ícone de folha Baixa emissão de carbono Somente leitura: asia-northeast1 1-OR
asia-south1 1-OR
europe-west2 1-OR
europe-west9 1-OR
us-east1 Carolina do Sul Somente leitura: us-central1 1-OR
us-west1 1-OR
us-east4 Virgínia do Norte
us-east5 Columbus
us-south1 Dallas
us-west1 Oregon ícone de folha Baixa emissão de carbono
us-west2 Los Angeles
us-west3 Salt Lake City
us-west4 Las Vegas
Europa
europe-central2 Varsóvia
europe-north1 Finlândia ícone de folha Baixa emissão de carbono
europe-southwest1 Madri
europe-west1 Bélgica ícone de folha Baixa emissão de carbono Somente leitura: us-central1 1-OR
us-west1 1-OR
europe-west2 Londres ícone de folha Baixa emissão de carbono
europe-west3 Frankfurt ícone de folha Baixa emissão de carbono
europe-west4 Países Baixos
europe-west6 Zurique ícone de folha Baixa emissão de carbono
europe-west8 Milão
europe-west9 Paris ícone de folha Baixa emissão de carbono
europe-west10 Berlim
europe-west12 Turim
Ásia-Pacífico
asia-east1 Taiwan
asia-east2 Hong Kong
asia-northeast1 Tóquio
asia-northeast2 Osaka
asia-northeast3 Seul
asia-south1 Mumbai
asia-south2 Délhi
asia-southeast1 Singapura
asia-southeast2 Jacarta
australia-southeast1 Sydney
australia-southeast2 Melbourne
Oriente Médio
me-central1 Doha
me-central2 Damã
me-west1 Tel Aviv
África
africa-south1 Joanesburgo

Replicação

As configurações regionais de base contêm três réplicas de leitura/gravação. Cada mutação do Spanner requer um quórum de gravação composto de uma maioria de réplicas votantes. Os quóruns de gravação são formados a partir de duas das três réplicas em configurações regionais. Para mais informações sobre regiões líderes e réplicas de votação, consulte Replicação.

É possível criar uma configuração de instância regional personalizada e adicionar réplicas somente leitura opcionais. Réplicas somente leitura ajudam a escalonar leituras e dar suporte a leituras desatualizadas de baixa latência. Essas réplicas somente leitura não fazem parte dos quóruns de gravação e não afetam o SLA do Spanner >= 99, 99% para instâncias regionais. É possível adicionar locais listados na coluna "Região opcional" como réplicas somente leitura opcionais. Se o local escolhido não aparecer, solicite uma nova região opcional de réplica somente leitura. Para mais informações, consulte Réplicas somente leitura.

Práticas recomendadas de desempenho para configurações regionais

Para um desempenho ideal, siga estas práticas recomendadas:

Configurações multirregionais

As configurações regionais do Spanner replicam dados entre várias zonas dentro de uma única região. No entanto, uma configuração regional pode não ser ideal se:

  • Muitas vezes, seu aplicativo precisa ler dados de várias localizações geográficas (por exemplo, para exibir dados a usuários na América do Norte e na Ásia).
  • As gravações são originadas de um local diferente das leituras. Por exemplo, se você tiver grandes cargas de trabalho de gravação na América do Norte e de leitura na Europa.

As configurações multirregionais podem:

  • Disponibilize gravações de várias regiões.
  • Manter a disponibilidade em caso de falhas regionais.
  • Proporcionam maior disponibilidade e SLAs do que as configurações regionais.

Com as configurações multirregionais, é possível replicar os dados do banco de dados em várias zonas em diversas regiões, conforme definido pela configuração da instância. Essas outras réplicas permitem que você leia dados com menor latência de vários locais próximos ou dentro da região na configuração.

No entanto, há desvantagens, porque em uma configuração multirregional, as réplicas de quórum (leitura/gravação) são distribuídas por mais de uma região. É possível notar latência de rede adicional quando essas réplicas se comunicam entre si para formar um quórum de gravação. As leituras não precisam de quórum. O resultado é que o aplicativo alcança leituras mais rápidas em mais lugares ao custo de um pequeno aumento na latência de gravação. Para mais informações, consulte O papel das réplicas em gravações e leituras.

Configurações disponíveis

O Spanner oferece as seguintes configurações básicas de instância multirregional:

Um continente

Nome da configuração básica Local Regiões de leitura/gravação Regiões somente leitura Região de testemunha Região opcional
asia1 Ásia Tóquio: asia-northeast1 L,2R
Osaka: asia-northeast2 2R
Nenhuma Seul: asia-northeast3 Somente leitura: us-west1 1-OR
us-east5 1-OR
asia2 R Ásia Mumbai: asia-south1 L,2R
Délhi: asia-south2 2R
Singapura: asia-southeast1 1R
Nenhuma Nenhuma
eur3 Europa Bélgica: europe-west1 L,2R
Países Baixos: europe-west4 2R
Nenhuma Finlândia: europe-north1
eur5 Europa Londres: europe-west2 L,2R
Bélgica: europe-west1 2R
Nenhuma Países Baixos: europe-west4 Somente leitura: us-central1 1-OR
us-east1 1-OR
eur6 Europa Países Baixos: europe-west4 L,2R
Frankfurt: europe-west3 2R
Nenhuma Zurique: europe-west6 Somente leitura: us-east1 2-OR
nam3 América do Norte Virgínia do Norte: us-east4 L,2R
Carolina do Sul: us-east1 2R
Nenhuma Iowa: us-central1 Somente leitura: us-west2 1-OR
asia-southeast1 1-OR
asia-southeast2 1-OR
europe-west1 1-OR
europe-west2 1-OR
nam6 América do Norte Iowa: us-central1 L,2R
Carolina do Sul: us-east1 2R
Oregon: us-west1 1R
Los Angeles: us-west2 1R
Oklahoma: us-central2
nam7 América do Norte Iowa: us-central1 L,2R
Virgínia do Norte: us-east4 2R
Nenhuma Oklahoma: us-central2 Somente leitura: us-east1 2-OR
us-south1 1-OR
europe-west1 2-OR
nam8 América do Norte Los Angeles: us-west2 L,2R
Oregon: us-west1 2R
Nenhuma Salt Lake City: us-west3 Somente leitura: asia-southeast1 2R
europe-west2 2R
nam9 América do Norte Virgínia do Norte: us-east4 L,2R
Iowa: us-central1 2R
Oregon: us-west1 2R Carolina do Sul: us-east1
nam10 América do Norte Iowa: us-central1 L,2R
Salt Lake City: us-west3 2R
Nenhuma Oklahoma: us-central2
nam11 América do Norte Iowa: us-central1 L,2R
Carolina do Sul: us-east1 2R
Nenhuma Oklahoma: us-central2 Somente leitura: us-west1 1-OR
nam12 América do Norte Iowa: us-central1 L,2R
Virgínia do Norte: us-east4 2R
Oregon: us-west1 2R Oklahoma: us-central2
nam13 América do Norte Oklahoma: us-central2 L,2R
Iowa: us-central1 2R
Nenhuma Salt Lake City: us-west3
nam14 América do Norte Norte da Virgínia: us-east4 L,2R
Montreal: northamerica-northeast1 2R
Nenhuma Carolina do Sul: us-east1
nam15 América do Norte Dallas: us-south1 L,2R
Norte da Virgínia: us-east4 2R
Nenhuma Iowa: us-central1

Três continentes

Nome da configuração básica Locais Regiões de leitura/gravação Regiões somente leitura Região de testemunha Região opcional
nam-eur-asia1 América do Norte
Europa
Ásia
Iowa: us-central1 L,2R
Oklahoma: us-central2 2R
Bélgica: europe-west1 2R
Taiwan: asia-east1 2R
Carolina do Sul: us-east1 Somente leitura: us-west2 1-OR
nam-eur-asia3 América do Norte
Europa
Ásia
Iowa: us-central1 L,2R
Sul Carolina: us-east1 2R
Bélgica: europe-west1 1R
Países Baixos: europe-west4 1R
Taiwan: asia-east1 2R
Oklahoma: us-central2
  • L: região líder padrão. Para mais informações, consulte Modificar a região líder de um banco de dados.

  • 1R: uma réplica na região.

  • 2R: duas réplicas na região.

  • 1-OR: uma réplica opcional. É possível criar uma configuração de instância regional personalizada e adicionar uma réplica somente leitura opcional. Para mais informações, acesse Criar uma configuração de instância personalizada.

  • 2-OR: até duas réplicas opcionais. É possível criar uma configuração de instância regional personalizada e adicionar uma ou duas réplicas somente leitura opcionais. Recomendamos adicionar dois (quando possível) para ajudar a manter a baixa latência de leitura. Para mais informações, acesse Criar uma configuração de instância personalizada.

  • R: Essa configuração de instância é restrita com uma lista de permissões. Para ter acesso, entre em contato com seu gerente técnico de contas.

Benefícios

Instâncias multirregionais oferecem estas vantagens principais:

  • Disponibilidade de 99,999%: maior do que a disponibilidade de 99,99% fornecida pelas configurações regionais do Spanner.

  • Distribuição de dados: o Spanner replica automaticamente seus dados entre regiões com fortes garantias de consistência. Isso permite que seus dados sejam armazenados onde forem usados, o que pode reduzir a latência e melhorar a experiência do usuário.

  • Consistência externa: mesmo que o Spanner replique em locais geograficamente distantes, ainda é possível usá-lo como se fosse um banco de dados em execução em uma única máquina. As transações têm a garantia de serem serializáveis, e a ordem das transações dentro do banco de dados é a mesma em que os clientes observam as transações que foram confirmadas. A consistência externa é uma garantia mais forte do que a "consistência forte", que é oferecida por alguns outros produtos. Saiba mais sobre essa propriedade em TrueTime e consistência externa.

Replicação

Cada configuração multirregional de base contém duas regiões designadas como regiões de leitura/gravação, cada uma com duas réplicas de leitura/gravação. Uma dessas regiões de leitura/gravação é designada como região líder padrão, o que significa que ela contém as réplicas líderes do seu banco de dados. O Spanner também coloca uma réplica testemunha em uma terceira região chamada de região testemunha.

Cada vez que o cliente emite uma mutação para seu banco de dados, forma-se um quórum de gravação, que consiste em uma das réplicas da região líder padrão e quaisquer duas das quatro réplicas votantes adicionais. O quórum pode ser formado por réplicas de duas ou três das regiões que compõem suas configurações, dependendo de quais outras réplicas participam da votação. Além dessas cinco réplicas votantes, algumas configurações de base multirregional contêm réplicas somente leitura para exibir leituras de baixa latência. As regiões que contêm réplicas somente leitura são chamadas de regiões somente leitura.

Em geral, as regiões votantes em uma configuração multirregional são colocadas geograficamente próximas (uma distância inferior a 1.600 km) para formar um quórum de baixa latência que permite gravações rápidas (saiba mais). No entanto, as regiões ainda estão suficientemente distantes, geralmente algumas centenas de quilômetros, para evitar falhas coordenadas. Além disso, se o aplicativo cliente estiver em uma região não líder, o Spanner usará o roteamento com reconhecimento de líder para rotear transações de leitura e gravação dinamicamente a fim de reduzir a latência no banco de dados. Para mais informações, consulte Roteamento com reconhecimento de líder.

É possível criar uma configuração de instância multirregional personalizada com réplicas somente leitura opcionais. As réplicas somente leitura personalizadas que você criar não poderão ser incluídas nos quóruns de gravação. Você pode adicionar os locais listados na coluna "Região opcional" como réplicas somente leitura opcionais. Se você não encontrar o local escolhido para a réplica somente leitura, solicite uma nova região opcional de réplica somente leitura. Para mais informações, consulte Réplicas somente leitura.

Práticas recomendadas de desempenho para configurações multirregionais

Para um desempenho ideal, siga estas práticas recomendadas:

  • Crie um esquema que previna uso excessivo do ponto de acesso e outros problemas de desempenho.
  • Coloque os recursos de computação para cargas de trabalho de gravação pesadas dentro ou próximos da região líder padrão para conseguir a latência de gravação ideal.
  • Use uma inatividade de pelo menos 15 segundos para ter o desempenho de leitura ideal fora da região líder padrão.
  • Coloque os recursos de computação essenciais em, no mínimo, duas regiões para evitar a dependência de uma única região para suas cargas de trabalho. Uma boa opção é colocá-los ao lado das duas regiões de leitura/gravação diferentes para que nenhuma interrupção de região única não afete todo o aplicativo.
  • Provisione capacidade de computação suficiente para manter o uso total de CPU de alta prioridade abaixo de 45% em cada região.
  • Para a quantidade de capacidade por nó do Spanner, consulte o desempenho para configurações multirregionais.

Tipos de região

O Spanner tem três tipos de regiões: regiões de leitura/gravação, regiões somente leitura e regiões de testemunha.

Regiões de leitura/gravação

Cada configuração multirregional contém duas regiões de leitura/gravação, cada uma com duas réplicas de leitura/gravação.

Uma dessas regiões de leitura/gravação é designada como região líder padrão. Um líder é selecionado entre as réplicas na região líder padrão para cada divisão. Caso ocorra uma falha na réplica líder, a outra réplica na região líder padrão assume automaticamente a liderança. Na realidade, as líderes executam verificações de integridade em si mesmas e podem desistir da liderança preventivamente se detectarem que não estão íntegras. Na maioria dos casos, quando a região líder padrão retorna a um estado íntegro, ela volta a assumir a liderança automaticamente.

As gravações são processadas primeiro na região líder padrão. É possível monitorar a porcentagem de réplicas em uma determinada região usando a métrica de monitoramento instance/leader_percentage_by_region. Para mais informações, consulte Métricas do Spanner.

A segunda região de leitura/gravação contém mais réplicas que disponibilizam leituras e participam da votação para confirmar as gravações. Essas réplicas adicionais na segunda região de leitura/gravação estão qualificadas para serem líderes. No caso improvável de perda de todas as réplicas na região líder padrão, novas réplicas líderes são escolhidas a partir da segunda região de leitura/gravação.

É possível configurar a região líder de um banco de dados seguindo as instruções em Alterar a região líder de um banco de dados. Para mais informações, consulte Configurar a região líder padrão.

Regiões somente leitura

As regiões somente leitura contêm réplicas somente leitura que podem disponibilizar leituras de baixa latência a clientes que estejam fora das regiões de leitura/gravação. As réplicas somente leitura mantêm uma cópia completa dos dados, que são replicados a partir de réplicas de leitura/gravação. Elas não participam da votação sobre a confirmação de gravações, portanto, nunca contribuem para qualquer latência de gravação.

Algumas configurações multirregionais de base contêm réplicas somente leitura. Também é possível criar uma configuração de instância personalizada e adicionar réplicas somente leitura às configurações da instância personalizada para escalonar leituras e oferecer suporte a leituras desatualizadas de baixa latência. Todas as réplicas somente leitura estão sujeitas à capacidade de computação e aos custos de armazenamento do banco de dados. Além disso, adicionar réplicas somente leitura a uma configuração de instância não altera os SLAs do Spanner da configuração da instância. Para mais informações, consulte Réplicas somente leitura.

Regiões testemunhas

Uma região testemunha contém uma réplica testemunha, que é usada para votar em gravações. As testemunhas se tornam importantes no raro caso de as regiões de leitura/gravação ficarem indisponíveis.

Mover uma instância

É possível mover sua instância do Spanner de qualquer configuração de instância para qualquer configuração de instância, inclusive entre configurações regionais e multirregionais. Mover a instância não causa inatividade, e o Spanner continua a fornecer as garantias de transação normais durante a movimentação.

Para saber mais sobre a movimentação de instâncias do Spanner, consulte Mover uma instância.

Configurar a região líder padrão

Para alterar o local da região líder padrão do seu banco de dados para se aproximar dos clientes e reduzir a latência do aplicativo, altere a região líder para qualquer instância do Spanner que use uma configuração multirregional. Para instruções sobre como alterar o local da região líder, consulte Alterar a região líder de um banco de dados. As únicas regiões qualificadas para se tornarem a região líder padrão do banco de dados são as regiões de leitura e gravação na configuração multirregional.

A região líder é responsável por processar todas as gravações no banco de dados. Portanto, se a maior parte do tráfego vier de uma região geográfica, será possível movê-lo para essa região para reduzir a latência. Atualizar a região líder padrão é barato e não envolve transferências de dados. O novo valor leva alguns minutos para entrar em vigor.

Alterar a região líder padrão é uma mudança de esquema, que usa uma operação de longa duração. Se necessário, é possível ver o status da operação de longa duração.

Vantagens e desvantagens: configurações regionais versus multirregionais

Configuração Disponibilidade Latência Custo Localidade dos dados
Regional 99,99% Menores latências de gravação dentro da região. Custo mais baixo, consulte a pricing. Permite a governança de dados geográficos.
Multirregional 99,999% Menores latências de leitura de várias regiões geográficas, um pequeno aumento na latência de gravação. Custo mais elevado, consulte a pricing. Distribui dados em várias regiões dentro da configuração.

A seguir