DynamoDB - Ikhtisar

DynamoDB memungkinkan pengguna membuat database yang mampu menyimpan dan mengambil data dalam jumlah berapa pun, dan melayani lalu lintas dalam jumlah berapa pun. Secara otomatis mendistribusikan data dan lalu lintas melalui server untuk secara dinamis mengelola permintaan setiap pelanggan, dan juga mempertahankan kinerja yang cepat.

DynamoDB vs. RDBMS

DynamoDB menggunakan model NoSQL, yang artinya menggunakan sistem non-relasional. Tabel berikut menyoroti perbedaan antara DynamoDB dan RDBMS -

Tugas Umum RDBMS DynamoDB
Connect to the Source Ini menggunakan koneksi persisten dan perintah SQL. Ini menggunakan permintaan HTTP dan operasi API
Create a Table Struktur fundamentalnya adalah tabel, dan harus ditentukan. Ini hanya menggunakan kunci utama, dan tidak ada skema saat pembuatan. Ini menggunakan berbagai sumber data.
Get Table Info Semua info tabel tetap dapat diakses Hanya kunci utama yang diungkapkan.
Load Table Data Ini menggunakan baris yang terbuat dari kolom. Dalam tabel, ini menggunakan item yang terbuat dari atribut
Read Table Data Ini menggunakan pernyataan SELECT dan pernyataan pemfilteran. Ini menggunakan GetItem, Query, dan Scan.
Manage Indexes Ini menggunakan indeks standar yang dibuat melalui pernyataan SQL. Modifikasi itu terjadi secara otomatis pada perubahan tabel. Ini menggunakan indeks sekunder untuk mencapai fungsi yang sama. Ini membutuhkan spesifikasi (kunci partisi dan kunci urutkan).
Modify Table Data Ini menggunakan pernyataan UPDATE. Ini menggunakan operasi UpdateItem.
Delete Table Data Ini menggunakan pernyataan DELETE. Ini menggunakan operasi DeleteItem.
Delete a Table Ini menggunakan pernyataan DROP TABLE. Ini menggunakan operasi DeleteTable.

Keuntungan

Dua keuntungan utama DynamoDB adalah skalabilitas dan fleksibilitas. Ini tidak memaksa penggunaan sumber dan struktur data tertentu, memungkinkan pengguna untuk bekerja dengan hampir semua hal, tetapi dengan cara yang seragam.

Desainnya juga mendukung berbagai penggunaan mulai dari tugas dan operasi yang lebih ringan hingga fungsionalitas perusahaan yang menuntut. Ini juga memungkinkan penggunaan sederhana dari berbagai bahasa: Ruby, Java, Python, C #, Erlang, PHP, dan Perl.

Batasan

DynamoDB memang mengalami keterbatasan tertentu, namun, batasan ini tidak selalu menimbulkan masalah besar atau menghambat pengembangan yang solid.

Anda dapat memeriksanya dari poin-poin berikut -

  • Capacity Unit Sizes- Unit kapasitas baca adalah pembacaan konsisten tunggal per detik untuk item yang tidak lebih dari 4KB. Unit kapasitas tulis adalah satu tulis per detik untuk item yang tidak lebih besar dari 1 KB.

  • Provisioned Throughput Min/Max- Semua tabel dan indeks sekunder global memiliki minimal satu unit kapasitas baca dan tulis. Maksimal tergantung pada wilayah. Di AS, 40 ribu baca dan tulis tetap menjadi batasan per tabel (80 ribu per akun), dan wilayah lain memiliki batasan 10 ribu per tabel dengan batasan akun 20 ribu.

  • Provisioned Throughput Increase and Decrease - Anda dapat meningkatkannya sesering yang diperlukan, tetapi penurunan tetap dibatasi tidak lebih dari empat kali sehari per tabel.

  • Table Size and Quantity Per Account - Ukuran tabel tidak memiliki batasan, tetapi akun memiliki batas 256 tabel kecuali Anda meminta batas yang lebih tinggi.

  • Secondary Indexes Per Table - Lima lokal dan lima global diizinkan.

  • Projected Secondary Index Attributes Per Table - DynamoDB memungkinkan 20 atribut.

  • Partition Key Length and Values - Panjang minimumnya adalah 1 byte, dan maksimum pada 2048 byte, namun, DynamoDB tidak membatasi nilai.

  • Sort Key Length and Values - Panjang minimumnya adalah 1 byte, dan maksimum 1024 byte, tanpa batas nilai kecuali tabelnya menggunakan indeks sekunder lokal.

  • Table and Secondary Index Names - Nama harus terdiri dari minimal 3 karakter, dan maksimal 255. Nama tersebut menggunakan karakter berikut: AZ, az, 0-9, “_”, “-”, dan “.”.

  • Attribute Names - Satu karakter tetap minimum, dan maksimum 64KB, dengan pengecualian untuk kunci dan atribut tertentu.

  • Reserved Words - DynamoDB tidak mencegah penggunaan kata yang dicadangkan sebagai nama.

  • Expression Length- String ekspresi memiliki batas 4KB. Ekspresi atribut memiliki batas 255 byte. Variabel substitusi sebuah ekspresi memiliki batas 2MB.