DynamoDB - podstawowe pojęcia
Przed użyciem DynamoDB musisz zapoznać się z jego podstawowymi komponentami i ekosystemem. W ekosystemie DynamoDB pracujesz z tabelami, atrybutami i elementami. Tabela zawiera zestawy elementów, a elementy zawierają zestawy atrybutów. Atrybut to podstawowy element danych, który nie wymaga dalszej dekompozycji, tj. Pole.
Klucz podstawowy
Klucze podstawowe służą jako sposób unikatowej identyfikacji elementów tabeli, a indeksy pomocnicze zapewniają elastyczność zapytań. Strumienie DynamoDB rejestrują zdarzenia poprzez modyfikację danych tabeli.
Tworzenie tabeli wymaga nie tylko ustawienia nazwy, ale także klucza podstawowego; który identyfikuje pozycje tabeli. Żadne dwa elementy nie mają wspólnego klucza. DynamoDB używa dwóch typów kluczy podstawowych -
Partition Key- Ten prosty klucz podstawowy składa się z pojedynczego atrybutu określanego jako „klucz partycji”. Wewnętrznie DynamoDB używa wartości klucza jako danych wejściowych dla funkcji skrótu w celu określenia miejsca przechowywania.
Partition Key and Sort Key - Ten klucz, nazywany „złożonym kluczem podstawowym”, składa się z dwóch atrybutów.
Klucz partycji i
Klucz sortowania.
DynamoDB stosuje pierwszy atrybut do funkcji skrótu i przechowuje razem elementy z tym samym kluczem partycji; z ich kolejnością określaną przez klucz sortowania. Elementy mogą udostępniać klucze partycji, ale nie mogą sortować kluczy.
Atrybuty klucza podstawowego dopuszczają tylko wartości skalarne (pojedyncze); oraz ciągi, liczby lub typy danych binarnych. Atrybuty niebędące kluczami nie mają tych ograniczeń.
Indeksy pomocnicze
Te indeksy umożliwiają wykonywanie zapytań dotyczących danych tabeli przy użyciu klucza alternatywnego. Chociaż DynamoDB nie wymusza ich użycia, optymalizują zapytania.
DynamoDB używa dwóch typów indeksów pomocniczych -
Global Secondary Index - Ten indeks zawiera klucze partycji i sortowania, które mogą różnić się od kluczy tabel.
Local Secondary Index - Ten indeks zawiera klucz partycji identyczny z tabelą, jednak jego klucz sortowania jest inny.
API
Operacje API oferowane przez DynamoDB obejmują te z płaszczyzny kontroli, płaszczyzny danych (np. Tworzenie, odczytywanie, aktualizowanie i usuwanie) oraz strumieni. W operacjach na płaszczyźnie sterowania tworzysz tabele i zarządzasz nimi za pomocą następujących narzędzi -
- CreateTable
- DescribeTable
- ListTables
- UpdateTable
- DeleteTable
Na płaszczyźnie danych wykonujesz operacje CRUD za pomocą następujących narzędzi -
Stwórz | Czytać | Aktualizacja | Usunąć |
---|---|---|---|
PutItem BatchWriteItem |
Zdobądź przedmiot BatchGetItem Pytanie Skanowanie |
UpdateItem | Usuń przedmiot BatchWriteItem |
Strumienie tabeli sterującej operacjami strumieniowymi. Możesz przejrzeć następujące narzędzia do transmisji strumieniowej -
- ListStreams
- DescribeStream
- GetShardIterator
- GetRecords
Udostępniona przepustowość
Podczas tworzenia tabeli określasz aprowizowaną przepływność, która rezerwuje zasoby na potrzeby odczytów i zapisów. Do pomiaru i ustawiania przepustowości służą jednostki pojemności.
Gdy aplikacje przekraczają ustawioną przepustowość, żądania kończą się niepowodzeniem. Konsola DynamoDB GUI umożliwia monitorowanie ustawionej i używanej przepustowości w celu lepszego i dynamicznego udostępniania.
Przeczytaj spójność
DynamoDB używa eventually consistent i strongly consistentczyta, aby wspierać dynamiczne potrzeby aplikacji. Ostatecznie spójne odczyty nie zawsze dostarczają aktualnych danych.
Silnie spójne odczyty zawsze dostarczają aktualne dane (z wyjątkiem awarii sprzętu lub problemów z siecią). Ostatecznie spójne odczyty służą jako ustawienie domyślne, wymagając ustawienia true wConsistentRead parametr, aby go zmienić.
Partycje
DynamoDB używa partycji do przechowywania danych. Te alokacje magazynu dla tabel mają kopie zapasowe SSD i automatycznie replikują się między strefami. DynamoDB zarządza wszystkimi zadaniami partycji, nie wymagając zaangażowania użytkownika.
Podczas tworzenia tabeli tabela przechodzi w stan CREATING, który przydziela partycje. Gdy osiągnie stan AKTYWNY, możesz wykonywać operacje. System zmienia partycje, gdy ich pojemność osiągnie maksimum lub gdy zmienisz przepustowość.