Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
DynamoDB の好きなところ
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Yuki Toyoda
September 24, 2020
Technology
270
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
DynamoDB の好きなところ
社内の「実践AWSゼミ」にて発表したスライドです
Yuki Toyoda
September 24, 2020
More Decks by Yuki Toyoda
See All by Yuki Toyoda
パフォーマンスクリティカルな領域へのRust活用戦略
helloyuk13
4
880
Context Oriented Programming of Kotlin
helloyuk13
3
5.3k
カジュアルコントリビュータと学ぶRustコンパイラ
helloyuk13
3
2k
2025 年の Rust はどこに向かっているのか?
helloyuk13
6
1.5k
RustでWeb開発コソコソ噂話
helloyuk13
15
20k
SeaQL Projectsについて
helloyuk13
1
650
年末ですし、今年のRustの進捗の話をしましょう
helloyuk13
2
3.1k
SwiftでAWS Lambda
helloyuk13
0
280
Rustハンズオン@エウレカ社
helloyuk13
22
11k
Other Decks in Technology
See All in Technology
【Snowflake Summit 2026 Recap!!】Snowflake Summit Deep Dive: Security & Governance
civitaspo
1
270
AIはどのように 組織のアジリティを変えるのか?
junki
4
1k
脆弱性対応、どこで線を引くか
rymiyamoto
1
420
Oracle AI Database@Azure:サービス概要のご紹介
oracle4engineer
PRO
6
2k
不要なレビューをAIにまかせて AIコーディングの環境改善を加速した
shoota
1
230
AI-DLCを “そのまま導入しなかった”話 ~組織に合わせてアジャストした 私たちの実践共有~
hiroramos4
PRO
0
210
Bucharest Tech Week 2026 - Guardians of the Cloud-Native Galaxy
edeandrea
PRO
0
120
FPGAの開発コンペでZephyrを使ってみた
iotengineer22
0
140
LayerXにおけるセキュリティ管理の現在地と次の一手
tosho
0
250
Flow 不死:AI 時代 DevOps 的不變本質
cheng_wei_chen
2
330
Claude Codeをどのように キャッチアップしているか
oikon48
13
8.6k
秘密度ラベル初心者が第1歩でつまづかないための「設計・運用」ポイント
seafay
PRO
0
210
Featured
See All Featured
Building an army of robots
kneath
306
46k
Lessons Learnt from Crawling 1000+ Websites
charlesmeaden
PRO
1
1.3k
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
16
2k
Why You Should Never Use an ORM
jnunemaker
PRO
61
9.9k
Large-scale JavaScript Application Architecture
addyosmani
515
110k
Bash Introduction
62gerente
615
220k
How to Think Like a Performance Engineer
csswizardry
28
2.7k
What the history of the web can teach us about the future of AI
inesmontani
PRO
1
620
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
62
44k
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
37
6.5k
Deep Space Network (abreviated)
tonyrice
0
210
The SEO Collaboration Effect
kristinabergwall1
1
490
Transcript
DynamoDB の 好きなところ AWS ゼミ 豊田
もくじ 1. DynamoDB とは 2. 整合性モデル 3. DynamoDB の前身 Dynamo
4. 個人的に思ういいところ
DynamoDB とは • マネージドの NoSQL。 • ドキュメント指向。 • 読み込み書き込みが速い。 ◦
読み込みは RTB サーバーでは満足できる速度ではないので、キャッシュの工夫や DynamoDB Acceralator (DAX) の助けが必要ではある ◦ プロダクトでは数億件のデータを入れているけれど、書き込みがよくスケールするのが本当に嬉し い✨ • AZ が関係ない。 • テーブル単位でキャパシティユニットによるスループットの管理ができる。
整合性モデル • 一番知っておいた方がいいことかも。 • 書き込み ◦ 2つ以上の AZ で書き込み完了確認が取れた時点で、書き込みが承認される。
• 読み込み ◦ 弱い整合性と強い整合性の2つを選べる。 ◦ 2つ以上の AZ で書き込み完了した時点から読み取りが可能になる(弱い整合性なら)。 ◦ 結果整合性を担保しているので、最新の書き込み状況がすぐには反映されないこともある。 ◦ 強い整合性の場合は一貫性を担保できるが、お金を倍消費する。 • 要するに一貫性が必要な場合には、使用するのは難しい。 ◦ その際は RDS を利用するなどするほうがよいかも。
DynamoDB の前身 Dynamo • 2007 年に「Dynamo: Amazon’s Highly Available Key-value
Store」という論文で発 表された。 • Consistent Hashing を利用したパーティショニングを採用しており、マスターがいな い脱中心化アーキテクチャになっていた。 • 一貫性(consistency)を設定可能で、可用性、レイテンシ、一貫性のバランスを調整 可能にしていた。 • 書き込みの際のコンフリクトを許容。Vector Clock という機構でクライアントが情報 を読み取ってコンフリクトを解消できるようにしていた。 • シンプルなキーバリューストア(DynamoDB はドキュメント指向) • これにインスパイアされて Apache Cassandra ができた。 • DynamoDB とはほぼ別物
個人的に思ういいところ • Lambda と相性がいいので、単純に Lambda の永続化機構として使いやすい。 • 基本的には保存容量を気にしなくていいので、無限に容量が膨らむ可能性のある データを入れておく際に安心して入れておける。 •
Batch Write で億単位のデータを高速に書き込みできる vs Redis。 • キャパシティがテーブル単位なので、設定を間違えても死ぬのはそのテーブルだ け。 • Dynamo Streams と組み合わせで、CQRS + ES アーキテクチャをこれひとつで実現 できる。