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
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.4k
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
EventBridge Connection
_kensh
5
680
個人最適 から 全体最適 へ AI情報共有会・AIギルド・AI-DLC で進める カンリーの組織展開
rfdnxbro
0
2.2k
Bucharest Tech Week 2026 - Reinventing testing practices in the AI era
edeandrea
PRO
1
130
Amazon Bedrock AgentCore ワークショップ JAWS UG TOHOKU / amazon-bedrock-agentcore-workshop-jawsug-tohoku-2026
gawa
9
600
Kubernetesにおける学習基盤とLLMOpsの概要
ry
1
230
就職⽀援サービスにおけるキャリアアドバイザーのシフトスケジューリング
recruitengineers
PRO
1
130
小さく始める AI 活用推進 ― 日経電子版 Web チームの事例/nikkei-tech-talk47
nikkei_engineer_recruiting
0
160
新規事業を牽引する技術選定 〜フルスタックTypeScript開発の実践事例〜
nullnull
3
380
新しいVibe Codingと”自走”について
watany
5
280
2026TECHFRESH畢業分享會 - Lightning Talk - 打造精準高效的 MCP 設計模式與測試實務
line_developers_tw
PRO
0
650
手塩にかけりゃいいってもんじゃない
ming_ayami
0
220
社内 AI エージェント Synapse と セマンティックレイヤーの育て方
hiroakis
2
1.6k
Featured
See All Featured
How to make the Groovebox
asonas
2
2.2k
The Cost Of JavaScript in 2023
addyosmani
55
10k
Future Trends and Review - Lecture 12 - Web Technologies (1019888BNR)
signer
PRO
0
3.6k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
666
130k
Six Lessons from altMBA
skipperchong
29
4.3k
Heart Work Chapter 1 - Part 1
lfama
PRO
7
36k
Fashionably flexible responsive web design (full day workshop)
malarkey
408
66k
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
31
10k
Marketing Yourself as an Engineer | Alaka | Gurzu
gurzu
0
220
The untapped power of vector embeddings
frankvandijk
2
1.8k
Why Mistakes Are the Best Teachers: Turning Failure into a Pathway for Growth
auna
0
150
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
231
23k
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 アーキテクチャをこれひとつで実現 できる。