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
MySQLで高トラフィックに立ち向かう
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
takashabe
January 15, 2015
Technology
1.8k
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
MySQLで高トラフィックに立ち向かう
社内LT大会#2で話した内容です。
takashabe
January 15, 2015
More Decks by takashabe
See All by takashabe
より良いターミナルでの生活を求めて
takashabe
0
72
OpenCensusでcustom context propagationとexporterを書いた話 / OpenCensus with custom context propagation and exporter
takashabe
0
1.8k
pubsub with concurrent
takashabe
1
960
社内ISUCONを開催した話
takashabe
0
1.7k
ISUCON大反省会
takashabe
0
2k
gitのブランチ戦略
takashabe
8
6.1k
サルでもわかるgit
takashabe
0
1.6k
playで複数DBする
takashabe
0
1.6k
GitHubの良さ
takashabe
2
2.3k
Other Decks in Technology
See All in Technology
FPC(フレキシブル)基板にZephyr実装してみた。
iotengineer22
0
170
LayerX コーポレートエンジニアリング室におけるサプライチェーンセキュリティへの取り組み / Supply Chain Security at LayerX Corporate Engineering
yuyatakeyama
3
840
飲食店もAIで。レジ締めやハンディシステムをつくってる話 / Using AI for restaurant management
vtryo
0
170
千葉での単身赴任からAWSをやり続け、千葉に戻ってきた話
yama3133
1
120
【FinOps】データドリブンな意思決定を目指して
z63d
0
330
元・セキュリティ学習経験0大学生による業務紹介 / An Introduction to the Job by a Former College Student with Zero Security Training Experience
nttcom
0
100
40代で“やっとエンジニアになれた”――閉じた学びを開き、空の青さを知る / 20260628 Naoki Takahashi
shift_evolve
PRO
4
850
螺旋型キャリアの生存戦略 / kinoko-conf2026
rakus_dev
1
970
脱SaaS!FDEを支えるプロビジョニングと分離設計
knih
0
300
【Snowflake Summit 2026 Recap!!】Snowflake Summit Deep Dive: Security & Governance
civitaspo
1
310
GitHub Copilot app最速の発信の裏側
tomokusaba
1
260
Microsoft のサポートとフィードバック総まとめ
murachiakira
PRO
0
110
Featured
See All Featured
Taking LLMs out of the black box: A practical guide to human-in-the-loop distillation
inesmontani
PRO
3
2.3k
How to Align SEO within the Product Triangle To Get Buy-In & Support - #RIMC
aleyda
2
1.6k
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
32
3.5k
Lessons Learnt from Crawling 1000+ Websites
charlesmeaden
PRO
1
1.3k
Crafting Experiences
bethany
1
190
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
31
3.2k
The Power of CSS Pseudo Elements
geoffreycrofte
82
6.3k
The Impact of AI in SEO - AI Overviews June 2024 Edition
aleyda
5
1.1k
Building Experiences: Design Systems, User Experience, and Full Site Editing
marktimemedia
0
540
B2B Lead Gen: Tactics, Traps & Triumph
marketingsoph
0
160
Jess Joyce - The Pitfalls of Following Frameworks
techseoconnect
PRO
1
170
Done Done
chrislema
186
16k
Transcript
MySQLで高トラフィックに立ち向かう LT大会#2 Takashi Abe Mynet Inc. 01/15 2015
前提 InnoDB MySQL以外の話もちょっとします 特定のサービス特性にフォーカスするものではありま せんが、ソーシャルゲームをベースにして話します
DBサーバへのトラフィック 参照系クエリ select 更新系クエリ insert, update, delete
よくある最小構成
参照系への負荷対策
スケールアップ 金の弾丸 ioDrive
スケールアウト スレーブの追加 MySQLのレプリケーション機能でマスタのデータを複製する キャッシュレイヤの追加 memcached, RedisなどのKVSを利用する 参照性能はRDBに比べて桁違いに良い 参照頻度の高いデータをメインにキャッシュに乗せる カードステータスなどのマスタデータ ユーザのニックネーム
スケールアウトした構成
更新系への負荷対策
スケールアップ 金の弾丸 ioDrive メモリガン積み インメモリならioDriveと同等以上の性能が出る Amazon RDSの場合最大244GBまで拡張可能
スケールアウト マスタの分割 DB、テーブルを複数サーバに分割し、クエリに応じて 動的に問合せ先サーバを選択する 分割方式より垂直分割/水平分割がある アプリケーション側での実装が多い
垂直分割
垂直分割 関係性の薄いデータをそれぞれ異なるDBに分散 接続先DBを変えるだけなので大して実装コストはそれ ほどない、はず (例) ユーザデータ系 ログ系 マスタデータ系
垂直分割イメージ
水平分割
水平分割 複数サーバで同じDBを用意し、キーとなるデータによっ て格納先を分割する DB名から一意に格納先のテーブルを特定出来ないの でサーバ振り分けの実装が重くなりがち キーの余剰、ハッシュ値などによって分割を行う
水平分割 分割例 userテーブル、user_idをキーにして分割する user_idを100で割った余剰をテーブル名のサフィック スにする user_00 ~ user_99のテーブルに分割可能 サーバA: user_00
~ user_49 サーバB: user_50 ~ user_99
水平分割イメージ
スケールアウトした構成
分割するタイミング 設計、制約がきついため途中から分割しようとするのは つらい スモールスタートする場合、最初から分割しておいて分 割された各DBを1台に格納しておく戦略もアリ 分割されてさえいれば、後から別サーバに乗せること も容易になる
注意点 異なるDBに格納されるのでjoinが使えなくなる 水平分割の場合 分割すればするほどパフォーマンス低下 串刺しで検索したい時など トランザクションが煩雑になる
まとめ
参照系 マスタスレーブ+KVSの鉄板構成 後からでもスケールアウトは比較的容易 更新系 垂直、水平分割でマスタへのトラフィックを分散させる 後からスケールアウトするのがつらいのでプロジェク トの始めに方針を検討する