DynamoDB - Обзор

DynamoDB позволяет пользователям создавать базы данных, способные хранить и извлекать любой объем данных и обслуживать любой объем трафика. Он автоматически распределяет данные и трафик по серверам для динамического управления запросами каждого клиента, а также поддерживает высокую производительность.

DynamoDB против СУБД

DynamoDB использует модель NoSQL, что означает, что он использует нереляционную систему. В следующей таблице показаны различия между DynamoDB и СУБД.

Общие задачи СУБД DynamoDB
Connect to the Source Он использует постоянное соединение и команды SQL. Он использует HTTP-запросы и операции API.
Create a Table Его фундаментальные структуры - это таблицы, и их необходимо определить. Он использует только первичные ключи и не использует схему при создании. Он использует различные источники данных.
Get Table Info Вся информация о таблице остается доступной Выявлены только первичные ключи.
Load Table Data Он использует строки, состоящие из столбцов. В таблицах используются элементы, состоящие из атрибутов.
Read Table Data Он использует операторы SELECT и операторы фильтрации. Он использует GetItem, Query и Scan.
Manage Indexes Он использует стандартные индексы, созданные с помощью операторов SQL. Изменения в нем происходят автоматически при изменении таблицы. Он использует вторичный индекс для достижения той же функции. Требуются спецификации (ключ раздела и ключ сортировки).
Modify Table Data Он использует инструкцию UPDATE. Он использует операцию UpdateItem.
Delete Table Data Он использует оператор DELETE. Он использует операцию DeleteItem.
Delete a Table Он использует оператор DROP TABLE. Он использует операцию DeleteTable.

Преимущества

Два основных преимущества DynamoDB - это масштабируемость и гибкость. Он не заставляет использовать определенный источник данных и структуру, позволяя пользователям работать практически с чем угодно, но единообразным образом.

Его дизайн также поддерживает широкий спектр использования - от легких задач и операций до требовательных корпоративных функций. Он также позволяет легко использовать несколько языков: Ruby, Java, Python, C #, Erlang, PHP и Perl.

Ограничения

DynamoDB действительно страдает определенными ограничениями, однако эти ограничения не обязательно создают огромные проблемы или препятствуют надежной разработке.

Вы можете просмотреть их со следующих пунктов -

  • Capacity Unit Sizes- Единица емкости чтения - это одно последовательное чтение в секунду для элементов размером не более 4 КБ. Единица емкости записи - это одна запись в секунду для элементов размером не более 1 КБ.

  • Provisioned Throughput Min/Max- Все таблицы и глобальные вторичные индексы имеют как минимум одну единицу емкости для чтения и одну единицу записи. Максимумы зависят от региона. В США ограничение на чтение и запись в 40 КБ остается ограничением для таблицы (80 КБ на учетную запись), а в других регионах ограничение составляет 10 КБ на таблицу с ограничением учетной записи 20 КБ.

  • Provisioned Throughput Increase and Decrease - Вы можете увеличивать это количество по мере необходимости, но снижение остается ограниченным до не более четырех раз в день на стол.

  • Table Size and Quantity Per Account - Размеры таблиц не имеют ограничений, но учетные записи имеют ограничение в 256 таблиц, если вы не запросите более высокое ограничение.

  • Secondary Indexes Per Table - Разрешены пять локальных и пять глобальных.

  • Projected Secondary Index Attributes Per Table - DynamoDB допускает 20 атрибутов.

  • Partition Key Length and Values - Их минимальная длина составляет 1 байт, а максимальная - 2048 байтов, однако DynamoDB не накладывает ограничений на значения.

  • Sort Key Length and Values - Его минимальная длина составляет 1 байт, а максимальная - 1024 байта, без ограничений для значений, если только его таблица не использует локальный вторичный индекс.

  • Table and Secondary Index Names - Имена должны содержать минимум 3 символа и максимум 255. В них используются следующие символы: AZ, az, 0-9, «_», «-» и «.».

  • Attribute Names - Один символ остается минимальным, а 64 КБ - максимальным, за исключением ключей и определенных атрибутов.

  • Reserved Words - DynamoDB не запрещает использование зарезервированных слов в качестве имен.

  • Expression Length- Строки выражений имеют ограничение в 4 КБ. Выражения атрибутов имеют ограничение в 255 байт. Переменные подстановки в выражении имеют ограничение в 2 МБ.