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とBloomFilterのムフフなカンケイ
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
co-sche
November 11, 2016
Technology
0
1.5k
DynamoDBとBloomFilterのムフフなカンケイ
メディアのための広告配信システム、A.J.A.でのDynamoDBとBloomFilterの活用事例
co-sche
November 11, 2016
Tweet
Share
More Decks by co-sche
See All by co-sche
PackerとAnsibleでコンパクトに始めるInfrastructure as Code
co_sche
0
260
Other Decks in Technology
See All in Technology
Context Engineeringの取り組み
nutslove
0
340
~Everything as Codeを諦めない~ 後からCDK
mu7889yoon
3
340
10Xにおける品質保証活動の全体像と改善 #no_more_wait_for_test
nihonbuson
PRO
2
240
Introduction to Sansan for Engineers / エンジニア向け会社紹介
sansan33
PRO
6
68k
Frontier Agents (Kiro autonomous agent / AWS Security Agent / AWS DevOps Agent) の紹介
msysh
3
170
CDKで始めるTypeScript開発のススメ
tsukuboshi
1
390
プロダクト成長を支える開発基盤とスケールに伴う課題
yuu26
4
1.3k
CDK対応したAWS DevOps Agentを試そう_20260201
masakiokuda
1
260
ブロックテーマでサイトをリニューアルした話 / 2026-01-31 Kansai WordPress Meetup
torounit
0
460
変化するコーディングエージェントとの現実的な付き合い方 〜Cursor安定択説と、ツールに依存しない「資産」〜
empitsu
4
1.4k
Webhook best practices for rock solid and resilient deployments
glaforge
1
290
Data Hubグループ 紹介資料
sansan33
PRO
0
2.7k
Featured
See All Featured
Stewardship and Sustainability of Urban and Community Forests
pwiseman
0
110
Practical Tips for Bootstrapping Information Extraction Pipelines
honnibal
25
1.7k
Docker and Python
trallard
47
3.7k
Agile Leadership in an Agile Organization
kimpetersen
PRO
0
80
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
659
61k
SEO for Brand Visibility & Recognition
aleyda
0
4.2k
The Curse of the Amulet
leimatthew05
1
8.5k
Thoughts on Productivity
jonyablonski
74
5k
[RailsConf 2023] Rails as a piece of cake
palkan
59
6.3k
Large-scale JavaScript Application Architecture
addyosmani
515
110k
Leveraging LLMs for student feedback in introductory data science courses - posit::conf(2025)
minecr
0
140
Unsuck your backbone
ammeep
671
58k
Transcript
DynamoDBͱBloomFilterͷ ϜϑϑͳΧϯέΠ
ࣗݾհ ฏদ ߛయ • A.J.A. ϓϩάϥϚʔɾΞʔΩςΫτ • നนͷ֗ ෑग़ •
Ϊλʔ͍ͬͺ͍࣋ͬͯΔ • ͓ڕ৯ΒΕͳ͍ • https://github.com/co-sche
None
લճɺBloomFilterͷಈ࡞ݪ ཧͳͲʹ͍ͭͯΛ͠·ͨ͠ɻ IUUQXXXTMJEFTIBSFOFUDPTDIFTT
A.J.A.ͰͲ͏ΘΕ͍ͯΔͷ͔Λ Γ͍ͨͱ͍͏্͕͕ͬͨͷͰɺࠓ ճͦͷลΛத৺ʹ͓͠͠·͢ɻ
͘͡ • DynamoDB • DynamoDBͷ׆༻ࣄྫ • DynamoDBͷ • BloomFilter •
DynamoDB with BloomFilter
DynamoDB
DynamoDB • AWSͷϑϧϚωʔδυͳ NoSQL DB • ΩϟύγςΟϢχοτͱ͍͏୯ҐͰRead/WriteΛݟ ੵͬͯઃఆ͢Δ͚ͩͰɺμϯλΠϜແ͠Ͱεέʔ ϧ •
ઃఆͨ͠ΩϟύҎ্ͷΞΫηεʹجຊ͑ΒΕͳ͍ • ઃఆͨ͠Ωϟύʹରͯ͠՝ۚ
DynamoDB׆༻ࣄྫ A.J.A.ͷ߹
ϒϥβΫοΩʔͷସͱͯ͠ಋೖ
֨ೲͯ͠Δใ • ͲΜͳ༰ͷࠂͳͷ͔ • ͲΜͳॴʹग़ͯΔͷ͔ • ͲΜͳબग़ͷ͞ΕํΛͨ͠ͷ͔
WriteͷλΠϛϯά • ϝσΟΞαΠτͰͷࠂΫϦοΫ࣌
ReadͷλΠϛϯά • ࠂओαΠτʹຒΊࠐ·ΕͨϏʔίϯλά ϑοΫ • PVCVͷϩάʹు͍ͯɺ͔࣍Βͷࠂબ ग़ʹ׆͔͢
͜ͷέʔεͰͷ • Read͠Α͏ͱ߲͕ͨ͠ݟ͔ͭͬͯݟ͔ͭ Βͳͯ͘ΩϟύγςΟϢχοτফඅ͞Ε Δ
A.J.A. Ձ֨.c̋m͞Μ͔ΒϏʔίϯ ड৴͔ͨ͠Β͜ͷID͕ͯ͞͠ɻ
DynamoDB ͕͚ͨ͞͠Ͳɺ ͦΜͳΜ͋ΒΜͰɻ
A.J.A. ͞Α͏͔ɻ ͢·Μͳɻ
DynamoDB ͓͏ɻ ͋ɺۚΖͯ͘Ͱɻ
͜ͷέʔεͰͷ • ReadͷλΠϛϯάࠂओαΠτʹຒΊࠐ·ΕͨϏʔίϯ ϑοΫ • Ձ֨.c̋mͷৄࡉϖʔδʹຒΊࠐ·ΕͨΒʁ • YAH̋̋!γϣοϐϯάͷߪೖྃϖʔδʹషΒΕͨΒʁ • ͜ΕΒͷϏʔίϯͷ΄ͱΜͲɺA.J.A.ࠂΛclickͯ͠ભҠ͠
ͨΘ͚Ͱͳ͍ແؔͳϏʔίϯ • ͭ·ΓɺReadͰݟ͔ͭΒͳ͍͜ͱ͕΄ͱΜͲ
͜ͷέʔεͰͷ • ΄ͱΜͲ͕ϛεώοτ͢ΔେྔͷRead • ↑ͷ෩͕ಥવਧ͖ߥΕ࢝ΊΔڪා • ͜ΕΒʹରͯ͠ɺΩϟύγςΟΛେྔʹݟੵ Βͳ͚ΕͳΒͳ͍ෆໟײ
A.J.A. σʔλͷ༗ແ͚ͩͰ ࣄલʹ͔Ε͍͍ͷʹ…
BloomFilter
BloomFilter • ཁૉΛ༩͑ɺޙʹ͍߹ΘͤΔͱʮΈͨ͜ͱ ͋ΔΘʔʯ͘Β͍ʹ͍֮͑ͯͯ͘ΕΔσʔλ ߏ • ཁૉΛ༩͑ͯͳ͍ͷʹ͔ͬͨͿΔ͜ͱ͕͋ Δ • ༩͑ͨͷʹ֮͑ͯͳ͍ͱ͍͏͜ͱɺઈରͳ
͍
ཁૉΛ༩͑ͯͳ͍ͷʹͬͨ ͔ͿΔ͜ͱ͕͋Δ ِཅੑ͕͋Δ
༩͑ͨͷʹ֮͑ͯͳ͍ͱ͍͏ ͜ͱɺઈରͳ͍ ِӄੑͳ͍
BloomFilter • ِཅੑΛڐ༰͢Δ͜ͱͰɺੌ·͘͡লεϖʔε Ͱཁૉͷ༗ແΛهԱ͢Δ͜ͱ͕Ͱ͖Δ • Ұཁૉ͋ͨΓbits
DynamoDB with BloomFilter • DynamoDBʹΫΤϦ͢ΔલʹBloomFilterʹฉ ͘͜ͱͰɺϋζϨReadΛ΄΅Χοτ • ِཅੑൃੜ͢Δ͕ɺͦΕʹΑͬͯى͜Δͷ ͨͩͷϋζϨReadͳͷͰͳ͠
DynamoDB with BloomFilter • A.J.A.ͷ߹ • PVϏʔίϯ 1000/s • DynamoDBͷΫΤϦ
50/s • 1 / 20 • ແؔͳPVϏʔίϯ͕ٸಅͯ͠ͳ͠
·ͱΊ • A.J.AͰɺBloomFilterΛDynamoDBͷલஈ ͷωΨςΟϒΩϟογϡͱͯ͠ར༻͍ͯ͠·͢ɻ
͓·͚ • ͜ͷྨͷਖ਼֬ੑΛͪΐͼͬͱ٘ਜ਼ʹͯ͠ɺ࣌ؒ తɾۭؒతίετΛେ෯ʹઅ͢Δσʔλߏ ɺཚσʔλߏͱݺΕ͍ͯ·͢ɻ • BloomFilterҎ֎ʹɺHyperLogLogMinHash ͱ͍͏ͷ͋Γ·͢ɻ • ͦΕͧΕ໘ന͕͋͞ΔͷͰɺௐͯΈͯԼ͍͞
Ͷʂ
Have a nice ཚʂ
͋Γ͕ͱ͏͍͟͝·ͨ͠ɻ