Nesta página, descrevemos como a instância do Memorystore para Valkey se comporta durante o escalonamento.
É possível escalonar a capacidade da instância das seguintes maneiras:
É possível mudar o número de fragmentos da instância. Isso é chamado de escalonamento horizontal. É possível escalonar uma instância horizontalmente de uma das seguintes maneiras:
Escalonamento horizontal: aumenta a capacidade da instância, o que dá a ela mais memória e capacidade de processamento para lidar com um volume maior de dados ou tráfego. A capacidade da instância é determinada pelo número de fragmentos nela.
Ao escalonar horizontalmente sua instância, o aplicativo pode lidar com uma demanda maior sem degradação de desempenho. Para escalonar horizontalmente uma instância, adicione fragmentos a ela.
Reduzir a escala: diminua a capacidade da instância, o que reduz o poder de processamento e a quantidade de memória disponível para armazenar dados. Isso acontece quando as demandas de dados do aplicativo diminuem e você precisa reduzir o uso de recursos para economizar custos. Para escalonar uma instância, reduza o número de fragmentos nela.
É possível mudar o tipo de nó da instância. Isso é chamado de escalonamento vertical. É possível escalonar uma instância verticalmente de uma das seguintes maneiras:
- Escalonar verticalmente: aumentar a capacidade da instância. A capacidade da instância é determinada pelo tipo de nó dela. Para aumentar a escala de uma instância,
mude o tipo de nó para um maior. Por exemplo, faça o escalonamento vertical da instância de um tipo de nó
standard-small
para um tipo de nóhighmem-medium
. Redução vertical: diminua a capacidade da instância. Para reduzir uma instância, mude o tipo de nó para um menor. Por exemplo, reduza o escalonamento da instância de um tipo de nó
highmem-medium
para um tipo de nóstandard-small
.
- Escalonar verticalmente: aumentar a capacidade da instância. A capacidade da instância é determinada pelo tipo de nó dela. Para aumentar a escala de uma instância,
mude o tipo de nó para um maior. Por exemplo, faça o escalonamento vertical da instância de um tipo de nó
Impacto do escalonamento
Durante uma operação de escalonamento, a disponibilidade da instância não é afetada. No entanto, quando você muda o número de fragmentos na instância, o Memorystore para Valkey reequilibra o espaço de chaves da instância. Isso pode causar um aumento na latência durante a operação de escalonamento.
Além disso, o impacto do escalonamento vertical da instância ao mudar o tipo de nó é semelhante ao que acontece com uma operação de manutenção.
Cenários de falha
Se você encontrar um erro durante a operação de escalonamento, provavelmente é devido a um dos seguintes cenários:
Você quer atualizar a contagem de fragmentos da sua instância, mas não tem memória livre suficiente para o tipo de nó
shared-core-nano
.Para resolver esse problema, aumente a escala da instância ou libere memória dos nós dela. Para liberar memória, faça o seguinte:
- Conecte-se a uma instância do Memorystore for Valkey.
- Para conferir detalhes sobre a instância, incluindo o endereço IP e o número da porta, use o comando
gcloud memorystore instances describe
. - Anote o endereço IP e o número da porta da instância.
Para receber informações sobre os nós da instância, use o seguinte comando:
valkey-cli -h IP_ADDRESS -p PORT_NUMBER cluster nodes
Substitua IP_ADDRESS e PORT_NUMBER pelos valores que você anotou na etapa anterior.
Anote o endereço IP e o número da porta de um nó que não tem espaço livre suficiente. O ID desse nó corresponde a um ID que aparece no erro.
Para se conectar a esse nó, use o seguinte comando:
valkey-cli -h IP_ADDRESS -p PORT_NUMBER
Substitua IP_ADDRESS e PORT_NUMBER pelos valores anotados na etapa anterior.
No prompt, insira o comando
info memory
.Na saída, aparecem valores para os parâmetros
used_memory
emaxmemory
.used_memory
é a quantidade de memória usada pelo nó, emaxmemory
é a quantidade de memória disponível para ele.Divida o valor do parâmetro
used_memory
pelo valor do parâmetromaxmemory
e verifique se o quociente é maior que 98%.Para liberar espaço para o nó, exclua algumas das chaves dele.
Digite o comando
info memory
novamente. Na saída, o valor do parâmetroused_memory
é menor.Divida o valor do parâmetro
used_memory
pelo valor do parâmetromaxmemory
e verifique se o quociente agora é menor que 98%. Se não for, exclua mais chaves.Para outros nós que não têm espaço livre suficiente, repita as etapas 4 a 11 deste procedimento.
Você fez o escalonamento para uma contagem de fragmentos menor que não tem capacidade para armazenar todas as chaves que o Memorystore para Valkey armazena na instância original. Para resolver isso, faça o escalonamento para uma contagem de fragmentos maior que possa conter todas as chaves armazenadas. Para mais informações sobre como aumentar o número de fragmentos da sua instância, consulte Aumentar a contagem de fragmentos.
Você fez o escalonamento para um tipo de nó menor que não tem capacidade para armazenar todos os dados que o Memorystore para Valkey armazena no tipo de nó original. Se isso acontecer, o Memorystore para Valkey vai fornecer um tipo de nó recomendado para reduzir escala vertical verticalmente.
Você atualizou o tipo de nó da instância e substituiu as configurações padrão do tipo de nó original ou essas configurações já foram substituídas. No entanto, o novo tipo de nó escalonado não é compatível com os valores das configurações padrão ou as configurações não são válidas para o tipo de nó. Se isso acontecer, o Memorystore para Valkey vai retornar um erro. Para resolver isso, modifique as configurações manualmente para que sejam válidas para o novo tipo de nó.
Você escalonou a instância durante um período de alta pressão de gravação (por exemplo, durante um teste de carga). Para resolver isso, faça o escalonamento durante períodos de baixo tráfego de instâncias.
Práticas recomendadas
Para ajudar você a dimensionar a capacidade da instância e aumentar a velocidade e a confiabilidade do escalonamento, faça isso durante períodos de baixo tráfego, sempre que possível. Para saber como monitorar o tráfego da instância, consulte Monitorar instâncias.