As traduções são geradas por tradução automática. Em caso de conflito entre o conteúdo da tradução e da versão original em inglês, a versão em inglês prevalecerá.
Minimizando o tempo de inatividade ElastiCache usando o Multi-AZ com Valkey e Redis OSS
Há vários casos em que, ElastiCache para Valkey e Redis, OSS pode ser necessário substituir um nó primário; isso inclui certos tipos de manutenção planejada e o evento improvável de uma falha no nó primário ou na zona de disponibilidade.
Essa substituição resulta em algum tempo de inatividade do cluster, mas se o multi-AZ estiver habilitado, o tempo de inatividade será minimizado. A função do nó primário fará failover automaticamente para uma das réplicas de leitura. Não há necessidade de criar e provisionar um novo nó primário, pois ele ElastiCache lidará com isso de forma transparente. O failover e a promoção de réplica garantem que você possa continuar a gravar no novo primário assim que a promoção estiver concluída.
ElastiCache também propaga o nome Domain Name Service (DNS) da réplica promovida. Isso ocorre porque, em seguida, se o seu aplicativo estiver gravando no endpoint primário, nenhuma alteração nesse endpoint será necessária no seu aplicativo. Se estiver lendo de endpoints individuais, altere o endpoint de leitura da réplica promovida a primária para o endpoint da nova réplica.
No caso de substituições de nó planejadas, iniciadas devido a atualizações de manutenção ou atualizações de autoatendimento, esteja ciente do seguinte:
Para OSS clusters Valkey e Redis, as substituições planejadas dos nós são concluídas enquanto o cluster atende às solicitações de gravação recebidas.
Para clusters desativados nos modos de OSS cluster Valkey e Redis com Multi-AZ habilitado e executados no mecanismo 5.0.6 ou posterior, as substituições planejadas dos nós são concluídas enquanto o cluster atende às solicitações de gravação recebidas.
Para clusters desativados nos modos de OSS cluster Valkey e Redis com Multi-AZ habilitado que são executados no mecanismo 4.0.10 ou anterior, você pode notar uma breve interrupção de gravação associada às atualizações. DNS Essa interrupção pode levar até alguns segundos. Esse processo é muito mais rápido do que recriar e provisionar um novo primário, que será o caso se você não habilitar o multi-AZ.
Você pode ativar o Multi-AZ usando o ElastiCache Management Console AWS CLI, o ou o. ElastiCache API
Habilitar o ElastiCache Multi-AZ em seu OSS cluster Valkey ou Redis (no grupo de replicação API eCLI,) melhora sua tolerância a falhas. Isso é verdade, especialmente nos casos em que o cluster primário de leitura/gravação do seu cluster se torna inacessível ou falha por qualquer motivo. O Multi-AZ só é compatível com OSS clusters Valkey e Redis com mais de um nó em cada fragmento.
Tópicos
Habilitar Multi-AZ
Você pode ativar o Multi-AZ ao criar ou modificar um cluster (APIou CLI grupo de replicação) usando o ElastiCache console ou o. AWS CLI ElastiCache API
Você pode habilitar o Multi-AZ somente em clusters Valkey ou Redis OSS (modo de cluster desativado) que tenham pelo menos uma réplica de leitura disponível. Clusters sem réplicas de leitura não fornece alta disponibilidade ou tolerância a falhas. Para obter informações sobre como criar um cluster com replicação, consulte Criação de um grupo de replicação do Valkey ou Redis OSS. Para obter informações sobre como adicionar uma réplica de leitura a um cluster com replicação, consulte Adição de uma réplica de leitura do Valkey ou do Redis OSS (modo cluster desabilitado).
Tópicos
Habilitação do multi-AZ (console)
Você pode habilitar o Multi-AZ usando o ElastiCache console ao criar um novo cluster Valkey ou Redis ou ao modificar um OSS cluster existente com replicação.
O Multi-AZ é ativado por padrão nos clusters Valkey ou Redis OSS (modo de cluster ativado).
Importante
ElastiCache ativará automaticamente o Multi-AZ somente se o cluster contiver pelo menos uma réplica em uma zona de disponibilidade diferente da primária em todos os fragmentos.
Ativando o Multi-AZ ao criar um cluster usando o console ElastiCache
Para obter mais informações sobre esse processo, consulte Criação de um cluster do Valkey (modo cluster desabilitado) (console). Tenha uma ou mais réplicas e habilite o Multi-AZ.
Habilitação do multi-AZ em um cluster existente (console)
Para obter mais informações sobre esse processo, consulte Modificação de um cluster Uso do AWS Management Console do ElastiCache.
Habilitar o recurso multi-AZ (AWS CLI)
O exemplo de código a seguir usa o AWS CLI para habilitar o Multi-AZ para o grupo de replicação. redis12
Importante
O grupo de replicação redis12
já deve existir e ter pelo menos uma réplica de leitura disponível.
Para Linux, macOS ou Unix:
aws elasticache modify-replication-group \ --replication-group-id
redis12
\ --automatic-failover-enabled \ --multi-az-enabled \ --apply-immediately
Para Windows:
aws elasticache modify-replication-group ^ --replication-group-id
redis12
^ --automatic-failover-enabled ^ --multi-az-enabled ^ --apply-immediately
A JSON saída desse comando deve ser semelhante à seguinte.
{
"ReplicationGroup": {
"Status": "modifying",
"Description": "One shard, two nodes",
"NodeGroups": [
{
"Status": "modifying",
"NodeGroupMembers": [
{
"CurrentRole": "primary",
"PreferredAvailabilityZone": "us-west-2b",
"CacheNodeId": "0001",
"ReadEndpoint": {
"Port": 6379,
"Address": "redis12-001.v5r9dc.0001.usw2.cache.amazonaws.com"
},
"CacheClusterId": "redis12-001"
},
{
"CurrentRole": "replica",
"PreferredAvailabilityZone": "us-west-2a",
"CacheNodeId": "0001",
"ReadEndpoint": {
"Port": 6379,
"Address": "redis12-002.v5r9dc.0001.usw2.cache.amazonaws.com"
},
"CacheClusterId": "redis12-002"
}
],
"NodeGroupId": "0001",
"PrimaryEndpoint": {
"Port": 6379,
"Address": "redis12.v5r9dc.ng.0001.usw2.cache.amazonaws.com"
}
}
],
"ReplicationGroupId": "redis12",
"SnapshotRetentionLimit": 1,
"AutomaticFailover": "enabling",
"MultiAZ": "enabled",
"SnapshotWindow": "07:00-08:00",
"SnapshottingClusterId": "redis12-002",
"MemberClusters": [
"redis12-001",
"redis12-002"
],
"PendingModifiedValues": {}
}
}
Para obter mais informações, consulte estes tópicos na AWS CLI Referência de comandos:
-
modify-replication-groupna Referência de AWS CLI Comandos.
Habilitar o recurso multi-AZ (ElastiCache API)
O exemplo de código a seguir usa a ElastiCache API para habilitar o Multi-AZ para o grupo de replicação redis12
.
nota
Para usar esse exemplo, o grupo de replicação redis12
já deve existir e ter pelo menos uma réplica de leitura disponível.
https://elasticache.us-west-2.amazonaws.com/ ?Action=ModifyReplicationGroup &ApplyImmediately=true &AutoFailover=true &MultiAZEnabled=true &ReplicationGroupId=redis12 &Version=2015-02-02 &SignatureVersion=4 &SignatureMethod=HmacSHA256 &Timestamp=20140401T192317Z &X-Amz-Credential=<credential>
Para obter mais informações, consulte esses tópicos na ElastiCache APIReferência:
Cenários de falha com respostas do multi-AZ
Antes da introdução do Multi-AZ, ElastiCache detectou e substituiu os nós com falha de um cluster recriando e reprovisionando o nó com falha. Se você habilitar o Multi-AZ, um nó primário com falha fará failover para a réplica com o menor atraso de replicação. A réplica selecionada é promovida automaticamente para primário, o que é muito mais rápido do que criar e reprovisionar um novo nó primário. Esse processo normalmente demora apenas alguns segundos até que você possa gravar novamente no cluster.
Quando o Multi-AZ está ativado, monitora ElastiCache continuamente o estado do nó primário. Se o nó primário falhar, uma das seguintes ações será realizada, dependendo do tipo da falha.
Tópicos
Cenários de falha quando somente o nó primário falha
Se somente o nó primário falhar, a réplica de leitura com o menor atraso de replicação será promovida a primária. Depois disso, uma réplica de leitura de substituição é criada e provisionada na mesma zona de disponibilidade que o primário com falha.
Quando somente o nó primário falha, o ElastiCache Multi-AZ faz o seguinte:
O nó primário com falha é colocado offline.
A réplica de leitura com o menor atraso de replicação é promovida a primário.
As gravações poderão ser retomadas assim que o processo de promoção estiver concluído, normalmente depois de apenas alguns segundos. Se seu aplicativo estiver gravando no endpoint primário, você não precisará alterar o endpoint para gravações ou leituras. ElastiCachepropaga o DNS nome da réplica promovida.
Uma réplica de leitura de substituição é executada e provisionada.
A réplica de leitura de substituição é executada na Zona de disponibilidade em que o nó primário com falha se encontrava, para que a distribuição de nós seja mantida.
As réplicas são sincronizadas com o novo nó primário.
Depois que a nova réplica estiver disponível, lembre-se dos seguintes efeitos:
-
Endpoint primário — Você não precisa fazer nenhuma alteração em seu aplicativo, porque o DNS nome do novo nó primário é propagado para o endpoint primário.
-
Endpoint leitor: o endpoint leitor é atualizado automaticamente para apontar para os novos nós de réplica.
Para obter informações sobre como encontrar os endpoints de um cluster, consulte os seguintes tópicos:
Cenários de falha quando o nó primário e algumas réplicas de leitura falham
Se o primário e pelo menos uma réplica de leitura falhar, a réplica disponível com o menor atraso de replicação será promovida a cluster primário. Novas réplicas de leitura também são criadas e provisionadas nas mesmas Zonas de disponibilidade que os nós com falha e a réplica que foi promovida a primário.
Quando o nó primário e algumas réplicas de leitura falham, o ElastiCache Multi-AZ faz o seguinte:
O nó primário com falha e as réplicas de leitura com falha são colocadas offline.
A réplica disponível com o menor atraso de replicação é promovida a nó primário.
As gravações poderão ser retomadas assim que o processo de promoção estiver concluído, normalmente depois de apenas alguns segundos. Se seu aplicativo estiver gravando no endpoint primário, não há necessidade de alterar o endpoint para gravações. ElastiCache propaga o DNS nome da réplica promovida.
Réplicas de substituição são criadas e provisionadas.
As réplicas de substituição são criadas nas Zonas de disponibilidade dos nós com falha, de modo que a distribuição de nós seja mantida.
Todos os clusters são sincronizados com o novo nó primário.
Faça as seguintes alterações no seu aplicativo depois que os novos nós estiverem disponíveis:
-
Endpoint primário: não faça alterações em sua aplicação. O DNS nome do novo nó primário é propagado para o endpoint primário.
-
Endpoint leitor: o endpoint leitor é atualizado automaticamente para apontar para os novos nós de réplica.
Para obter informações sobre como encontrar os endpoints de um grupo de replicação, consulte os seguintes tópicos:
Cenários de falha quando cluster inteiro falha
Se tudo falhar, todos os nós serão recriados e provisionados nas mesmas Zonas de disponibilidade que os nós originais.
Nesse cenário, todos os dados do cluster são perdidos devido à falha de cada nó no cluster. Essa ocorrência é rara.
Quando todo o cluster falha, o ElastiCache Multi-AZ faz o seguinte:
O nó primário e as réplicas de leitura com falha são colocados offline.
Um nó primário de substituição é criado e provisionado.
Réplicas de substituição são criadas e provisionadas.
As substituição são criadas nas Zonas de disponibilidade dos nós com falha, de modo que a distribuição de nós seja mantida.
Como o cluster inteiro falhou, os dados são perdidos, e todos os novos nós são iniciados a frio.
Como cada um dos nós de substituição tem o mesmo endpoint que o nó que ele está substituindo, não é necessário fazer alterações de endpoint no seu aplicativo.
Para obter informações sobre como encontrar os endpoints de um grupo de replicação, consulte os seguintes tópicos:
Recomendamos que você crie o nó primário e as réplicas de leitura em diferentes Zonas de disponibilidade para aumentar o nível de tolerância a falhas.
Teste do failover automático
Depois de habilitar o failover automático, você pode testá-lo usando o ElastiCache console AWS CLI, o. e. ElastiCache API
Ao testar, observe o seguinte:
-
Você pode usar essa operação para testar o failover automático em até 15 fragmentos (chamados de grupos de nós no ElastiCache API e AWS CLI) em qualquer período contínuo de 24 horas.
-
Se você chamar essa operação em fragmentos em clusters diferentes (chamados de grupos de replicação no API eCLI), poderá fazer as chamadas simultaneamente.
-
Em alguns casos, você pode chamar essa operação várias vezes em fragmentos diferentes no mesmo grupo de replicação Valkey ou Redis OSS (modo de cluster ativado). Nesses casos, a substituição do primeiro nó deve ser concluída antes que uma chamada subsequente possa ser feita.
-
Para determinar se a substituição do nó foi concluída, verifique os eventos usando o ElastiCache console da Amazon AWS CLI, o ou ElastiCache API o. Procure pelos seguintes eventos relacionados ao failover automático, listados aqui em ordem de ocorrência:
-
Mensagem do grupo de replicação:
Test Failover API called for node group <node-group-id>
-
Mensagem do cluster de cache:
Failover from primary node <primary-node-id> to replica node <node-id> completed
-
Mensagem do grupo de replicação:
Failover from primary node <primary-node-id> to replica node <node-id> completed
-
Mensagem do cluster de cache:
Recovering cache nodes <node-id>
-
Mensagem do cluster de cache:
Finished recovery for cache nodes <node-id>
Para obter mais informações, consulte:
-
Visualização de eventos do ElastiCache no ElastiCache Guia do usuário
-
DescribeEventsna ElastiCache APIReferência
-
describe-events na AWS CLI Referência de comandos.
-
Isso foi API projetado para testar o comportamento do seu aplicativo em caso ElastiCache de falha. Ela não foi projetada para ser uma ferramenta operacional para iniciar um failover a fim de resolver um problema com o cluster. Além disso, em certas condições, como eventos operacionais de grande escala, AWS pode bloquear issoAPI.
Tópicos
Testando o failover automático usando o AWS Management Console
Use o procedimento a seguir para testar o failover automático com o console.
Para testar o failover automático
-
Faça login no AWS Management Console e abra o ElastiCache console em https://console.aws.amazon.com/elasticache/
. -
No painel de navegação, escolha Valkey ou Redis. OSS
-
Na lista de clusters, escolha a caixa à esquerda do cluster que deseja testar. Esse cluster deve ter pelo menos um nó de réplica de leitura.
-
Na área Details, confirme se esse cluster está habilitado para Multi-AZ. Se o cluster não estiver habilitado para o Multi-AZ, escolha um cluster diferente ou modifique esse cluster para habilitar o Multi-AZ. Para obter mais informações, consulte Uso do AWS Management Console do ElastiCache.
Para Valkey ou Redis OSS (modo de cluster desativado), escolha o nome do cluster.
Para Valkey ou Redis OSS (modo de cluster ativado), faça o seguinte:
-
Escolha o nome do cluster.
-
Na página Shards, para o fragmento (chamado de grupo de nós no API eCLI) no qual você deseja testar o failover, escolha o nome do fragmento.
-
-
Na página Nodes, escolha Failover Primary.
-
Escolha Continue para fazer failover do primário ou Cancel para cancelar a operação e não fazer failover do nó primário.
Durante o processo de failover, o console continua a mostrar o status do nó como disponível. Para acompanhar o progresso do seu teste de failover, escolha Events no painel de navegação do console. Na guia Eventos, observe os eventos que indicam que o failover foi iniciado (
Test Failover API called
) e concluído (Recovery completed
).
Testando o failover automático usando o AWS CLI
Você pode testar o failover automático em qualquer cluster habilitado para Multi-AZ usando a AWS CLI operação. test-failover
Parâmetros
-
--replication-group-id
: obrigatório. O grupo de replicação (no console, cluster) que deve ser testado. -
--node-group-id
: obrigatório. O nome do grupo de nós nos quais você deseja testar o failover automático. Você pode testar um máximo de 15 grupos de nós em um período contínuo de 24 horas.
O exemplo a seguir usa o AWS CLI para testar o failover automático no grupo de nós redis00-0003
no cluster Valkey ou Redis OSS (modo de cluster ativado). redis00
exemplo Teste de failover automático
Para Linux, macOS ou Unix:
aws elasticache test-failover \ --replication-group-id
redis00
\ --node-group-idredis00-0003
Para Windows:
aws elasticache test-failover ^ --replication-group-id
redis00
^ --node-group-idredis00-0003
A saída do comando precedente é semelhante ao seguinte.
{
"ReplicationGroup": {
"Status": "available",
"Description": "1 shard, 3 nodes (1 + 2 replicas)",
"NodeGroups": [
{
"Status": "available",
"NodeGroupMembers": [
{
"CurrentRole": "primary",
"PreferredAvailabilityZone": "us-west-2c",
"CacheNodeId": "0001",
"ReadEndpoint": {
"Port": 6379,
"Address": "redis1x3-001.7ekv3t.0001.usw2.cache.amazonaws.com"
},
"CacheClusterId": "redis1x3-001"
},
{
"CurrentRole": "replica",
"PreferredAvailabilityZone": "us-west-2a",
"CacheNodeId": "0001",
"ReadEndpoint": {
"Port": 6379,
"Address": "redis1x3-002.7ekv3t.0001.usw2.cache.amazonaws.com"
},
"CacheClusterId": "redis1x3-002"
},
{
"CurrentRole": "replica",
"PreferredAvailabilityZone": "us-west-2b",
"CacheNodeId": "0001",
"ReadEndpoint": {
"Port": 6379,
"Address": "redis1x3-003.7ekv3t.0001.usw2.cache.amazonaws.com"
},
"CacheClusterId": "redis1x3-003"
}
],
"NodeGroupId": "0001",
"PrimaryEndpoint": {
"Port": 6379,
"Address": "redis1x3.7ekv3t.ng.0001.usw2.cache.amazonaws.com"
}
}
],
"ClusterEnabled": false,
"ReplicationGroupId": "redis1x3",
"SnapshotRetentionLimit": 1,
"AutomaticFailover": "enabled",
"MultiAZ": "enabled",
"SnapshotWindow": "11:30-12:30",
"SnapshottingClusterId": "redis1x3-002",
"MemberClusters": [
"redis1x3-001",
"redis1x3-002",
"redis1x3-003"
],
"CacheNodeType": "cache.m3.medium",
"DataTiering": "disabled",
"PendingModifiedValues": {}
}
}
Para acompanhar o progresso do seu failover, use a AWS CLI describe-events
operação.
Para obter mais informações, consulte:
-
test-failover na AWS CLI Referência de comandos.
-
describe-events na AWS CLI Referência de comandos.
Testando o failover automático usando o ElastiCache API
Você pode testar o failover automático em qualquer cluster habilitado com o Multi-AZ usando a ElastiCache API operação. TestFailover
Parâmetros
-
ReplicationGroupId
: obrigatório. O grupo de replicação (no console ou cluster) a ser testado. -
NodeGroupId
: obrigatório. O nome do grupo de nós nos quais você deseja testar o failover automático. Você pode testar um máximo de 15 grupos de nós em um período contínuo de 24 horas.
O exemplo a seguir testa o failover automático no grupo de nós redis00-0003
no grupo de replicação (no console, cluster) redis00
.
exemplo Teste do failover automático
https://elasticache.us-west-2.amazonaws.com/ ?Action=TestFailover &NodeGroupId=redis00-0003 &ReplicationGroupId=redis00 &Version=2015-02-02 &SignatureVersion=4 &SignatureMethod=HmacSHA256 &Timestamp=20140401T192317Z &X-Amz-Credential=<credential>
Para acompanhar o progresso do seu failover, use a ElastiCache DescribeEvents
API operação.
Para obter mais informações, consulte:
-
TestFailoverna ElastiCache APIReferência
-
DescribeEventsna ElastiCache APIReferência
Limitações no Multi-AZ
Esteja ciente das seguintes limitações para o Multi-AZ:
-
O Multi-AZ é suportado no Valkey e no Redis OSS versão 2.8.6 e posterior.
-
O Multi-AZ não é suportado em tipos de nós T1.
-
A OSS replicação do Valkey e do Redis é assíncrona. Portanto, quando um nó primário faz failover em uma réplica, uma pequena quantidade de dados pode ser perdida devido ao atraso da replicação.
Ao escolher a réplica a ser promovida a primária, ElastiCache escolhe a réplica com o menor atraso de replicação. Em outras palavras, ele escolha a réplica que é mais atual. Isso ajuda a minimizar a quantidade de dados perdidos. A réplica com o atraso de replicação mínimo pode estar na mesma zona de disponibilidade ou em outra em relação ao nó primário com falha.
-
Quando você promove manualmente réplicas de leitura para primárias em OSS clusters Valkey ou Redis com o modo de cluster desativado, você só pode fazer isso quando o failover automático e o Multi-AZ estão desativados. Para promover uma réplica de leitura para primário, execute as seguintes etapas:
-
Desabilite o Multi-AZ no cluster.
-
Desabilite o failover automático no cluster. Isso pode ser feito por meio do console desmarcando a caixa de seleção Failover automático para o grupo de replicação. Você também pode fazer isso usando o AWS CLI definindo a
AutomaticFailoverEnabled
propriedade comofalse
ao chamar aModifyReplicationGroup
operação. -
Promova a réplica de leitura para primário.
-
Habilite novamente o Multi-AZ.
-
-
ElastiCache para Redis OSS Multi-AZ e append-only file () AOF são mutuamente exclusivos. Se você habilitar um, não é possível habilitar o outro.
-
Uma falha de um nó pode ser causada pelo evento raro de falha total de uma zona de disponibilidade. Neste caso, a réplica que substitui o primário com falha é criada somente quando a zona de disponibilidade volta a ficar ativa. Por exemplo, considere um grupo de replicação com o primário em AZ-a e réplicas em AZ-b e AZ-c. Se o primário falhar, a réplica com o menor atraso de replicação será promovida a cluster primário. Em seguida, ElastiCache cria uma nova réplica no AZ-a (onde o primário com falha estava localizado) somente quando o AZ-a estiver de volta e disponível.
-
Uma reinicialização iniciada pelo cliente de um primário não aciona o failover automático. Outras reinicializações e falhas desencadeiam o failover automático.
-
Quando o primário é reiniciado, seus dados são limpos quando ele volta a ficar online. Quando as réplicas de leitura veem o cluster primário limpo, elas limpam suas cópias dos dados, o que causa perda de dados.
-
Depois que uma réplica de leitura foi promovida, as outras réplicas se sincronizam com o novo primário. Após a sincronização inicial, o conteúdo das réplicas é excluído, e eles sincronizam os dados do novo primário. Esse processo de sincronização causa uma breve interrupção, durante a qual as réplicas não são acessíveis. O processo de sincronização também causa um aumento de carga temporário no primário durante a sincronização com as réplicas. Esse comportamento é nativo do Valkey e do Redis OSS e não é exclusivo do Multi-AZ. ElastiCache Para obter detalhes sobre esse comportamento, consulte Replicação
no site do Valkey.
Importante
Para Valkey 7.2.6 e posterior ou Redis OSS versão 2.8.22 e posterior, você não pode criar réplicas externas.
Para OSS versões do Redis anteriores à 2.8.22, recomendamos que você não conecte uma réplica externa a um ElastiCache cluster habilitado para Multi-AZ. Essa configuração não suportada pode criar problemas que impedem a execução adequada ElastiCache do failover e da recuperação. Para conectar uma réplica externa a um ElastiCache cluster, certifique-se de que o Multi-AZ não esteja ativado antes de fazer a conexão.