Nesta página, descrevemos como configurar o tempo máximo de atraso de commit (gravação) para otimizar a capacidade de gravação no Spanner.
Visão geral
Para garantir a consistência dos dados, o Spanner envia solicitações de gravação para todas as réplicas de votação no banco de dados. Esse processo de replicação pode ter uma sobrecarga computacional. Para mais informações, consulte Replicação.
As gravações otimizadas para capacidade de transmissão oferecem a opção de amortizar esses custos de computação executando um grupo de gravações juntas. Para isso, o Spanner introduz um pequeno atraso e coleta um grupo de gravações que precisam ser enviadas aos mesmos participantes da votação. Executar gravações dessa forma pode proporcionar melhorias significativas na capacidade de processamento ao custo de um aumento leve na latência.
Comportamento padrão
Se você não definir um tempo de atraso de commit, o Spanner poderá definir um pequeno atraso se achar que isso vai amortizar o custo das suas gravações.
Casos de uso comuns
É possível definir manualmente o tempo de atraso das solicitações de gravação, dependendo das necessidades do seu aplicativo. Também é possível desativar os atrasos de confirmação para aplicativos que são altamente sensíveis à latência definindo o tempo máximo de atraso de confirmação como 0 ms.
Se você tiver um aplicativo tolerante à latência e quiser otimizar a capacidade de processamento, defina um tempo de atraso de confirmação mais longo. Isso melhora significativamente a capacidade de processamento, mas aumenta a latência de cada gravação. Por exemplo, se você estiver carregando em massa uma grande quantidade de dados e o aplicativo não se importar com a rapidez com que o Spanner grava dados individuais, defina o tempo de atraso do commit como um valor maior, como 100 ms. Recomendamos começar com um valor de 100 ms e ajustar para cima e para baixo até que as compensações de latência e capacidade atendam às suas necessidades. Para a maioria dos aplicativos, um valor entre 20 ms e 100 ms funciona melhor.
Se você tiver um aplicativo sensível à latência, o Spanner também será sensível à latência por padrão. Se você tiver uma carga de trabalho instável, o Spanner poderá definir um pequeno atraso. Você pode testar a definição de um valor de 0 ms para determinar se a latência reduzida ao custo de um aumento na taxa de transferência é razoável para seu aplicativo.
Definir tempos de atraso de commit mistos
É possível configurar diferentes tempos máximos de atraso de confirmação em subconjuntos de gravações. Se você fizer isso, o Spanner usará o menor tempo de espera configurado para o conjunto de gravações. No entanto, recomendamos escolher um único valor para a maioria dos casos de uso, já que isso resulta em um comportamento mais previsível.
Limitações
É possível definir um tempo de atraso de confirmação entre 0 e 500 ms. Definir atrasos de confirmação maiores que 500 ms resulta em um erro.
Definir o atraso máximo de confirmação em solicitações de confirmação
O parâmetro de atraso máximo de confirmação faz parte do método CommitRequest
. É possível acessar
esse método com a API RPC,
a API REST
ou usando a biblioteca de cliente do Cloud Spanner.
C#
Go
Java
Node.js
Python
Ruby
Monitorar a latência de solicitações de gravação
É possível monitorar a utilização da CPU e a latência do Spanner usando o consoleGoogle Cloud . Quando você define um tempo de atraso maior para suas solicitações de gravação, espere ver a utilização da CPU potencialmente diminuir, enquanto a latência aumenta. Para saber mais sobre a latência em solicitações do Spanner, consulte Capturar e visualizar a latência da solicitação da API Spanner.