DEV Community

Thiago Emidio
Thiago Emidio

Posted on

Entendendo o Amazon DynamoDB

Image description

Introdução:

O Amazon DynamoDB é um serviço de banco de dados NoSQL totalmente gerenciado, oferecido pela Amazon Web Services (AWS). Ele é projetado para lidar com grandes quantidades de tráfego de dados, proporcionando uma latência consistente.

Tabelas, Itens e Atributos:

Image description

  • Tabelas: O DynamoDB armazena dados em tabelas, que são coleções de itens.

  • Itens: Cada tabela contém zero ou mais itens. Um item é uma coleção de atributos.

  • Atributos: Cada atributo tem um nome e um valor. O valor pode ser um escalar (string, número, binário), um conjunto (conjunto de strings, números ou binários), ou um mapa (estrutura de dados aninhada).

Chaves Primárias:
Chave de Partição (Hash Key):
Uma chave de partição é usada para distribuir itens entre partições de armazenamento e e obrigatória para todas as tabelas.

Chave de Partição e Chave de Classificação (Range Key):
Além da chave de partição, uma chave de classificação é usada para ordenar os itens com a mesma chave de partição. É opcional.

Image description

Particionamento e Escalabilidade
DynamoDB distribui automaticamente dados entre várias partições físicas para gerenciar a carga de leitura e escrita, e também armazenar grandes volumes de dados. Cada partição é responsável por um subconjunto dos dados da tabela.

A chave de partição (hash key) é usada para determinar em qual partição física um item específico será armazenado. Isso garante uma distribuição uniforme dos dados.

Image description

Conforme os dados da sua tabela aumentam, o DynamoDB automaticamente adiciona mais partições.

Image description

Replicação e Disponibilidade:
As Global Tables permitem replicar dados entre várias regiões da AWS. Ao criar uma tabela global, o DynamoDB cria réplicas da tabela original em cada região especificada.

DynamoDB Streams captura todas as alterações de dados na tabela (inserções, atualizações, exclusões). Os eventos nas streams são ordenados, garantindo que as mudanças sejam aplicadas na mesma ordem em todas as réplicas, o que ajuda a manter a consistência dos dados.

Quando um item é atualizado em uma região, o DynamoDB propaga essa alteração para todas as outras réplicas de maneira assíncrona.

Se houver conflitos de escrita (por exemplo, quando o mesmo item é atualizado simultaneamente em diferentes regiões), o DynamoDB resolve esses conflitos usando uma abordagem de “Last Writer Wins”, onde a atualização mais recente (com base no timestamp) prevalece.

Image description

Conclusão
O DynamoDB fornece um mecanismo robusto para replicação e consistência de dados em múltiplas regiões AWS. Através do uso de streams e políticas de resolução de conflitos, ele mantém os dados sincronizados e atualizados, prevenindo a maioria dos problemas de dados desatualizados.

fontes:

Top comments (0)