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
TIPSTARを支えるCloud Spanner
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
MIXI ENGINEERS
PRO
October 18, 2025
Technology
70
1
Share
TIPSTARを支えるCloud Spanner
会津大学の学生団体「Zli」が主催するLT大会に参加し、MIXIのエンジニア職採用・技術文化に関する企業PRを実施した時の資料です。
MIXI ENGINEERS
PRO
October 18, 2025
More Decks by MIXI ENGINEERS
See All by MIXI ENGINEERS
AIエージェントで加速する開発と意思決定:ナレッジ蓄積型AIエージェントと対話型KPI分析の最前線
mixi_engineers
PRO
0
85
法務DXの最前線: ゼロからのAI導入とバックオフィスの変革 ~ 46の施策で検証した「コスト」と「リードタイム」削減の裏側 ~
mixi_engineers
PRO
0
57
AIで有人対応の品質チェックを"同じ物差し"に:CSの評価軸設計とプロンプト調整
mixi_engineers
PRO
0
31
AI活用を“個人技”で終わらせない ― 現場の自律性と成果を両立させた推進の裏側 ―
mixi_engineers
PRO
1
74
投資プロセス全体の再設計:投資先データ活用の取り組み
mixi_engineers
PRO
0
34
AI推進委員会とGemini Enterpriseが牽引する全社AI活用とナレッジ活用基盤の刷新
mixi_engineers
PRO
0
120
「プロンプトって何?」から始まった1年。 監査メソドロジーへのAIアシスタント実装と組織変革の記録
mixi_engineers
PRO
0
47
365日挑んだ、デザイナーAI活用・実務事例!圧倒的ボリュームで大公開
mixi_engineers
PRO
0
89
AIを前提に再設計する、採用プロセスの変革
mixi_engineers
PRO
0
56
Other Decks in Technology
See All in Technology
雑談は、センサーだった
bitkey
PRO
2
200
鹿野さんに聞く!CSSの最新トレンド Ver.2026
tonkotsuboy_com
2
110
古今東西SRE
okaru
1
130
GKE Agent SandboxでAIが生成したコードを 安全に実行してみた
lamaglama39
0
190
EMから幅を広げるために最近挑戦していること / Recent challenges I'm undertaking to expand my horizons beyond EM
hiro_torii
1
180
バイブコーディングで3倍早く⚪⚪を作ってみた
samakada
0
220
巨大プラットフォームを進化させる「第3のROI」
recruitengineers
PRO
2
2.4k
UIライブラリに依存しすぎないReact Native設計を目指して
grandbig
0
190
Digital Independence: Why, When and How
wannesrams
0
280
AWS Transform CustomでIaCコードを自由自在に変換しよう
duelist2020jp
0
240
AI駆動開発で生産性を追いかけたら、行き着いたのは品質とシフトレフトだった
littlehands
0
380
Agents CLI と Gemini Enterprise Agent Platform で マルチエージェント開発が楽しくなる!
kaz1437
0
240
Featured
See All Featured
Thoughts on Productivity
jonyablonski
76
5.1k
Optimizing for Happiness
mojombo
378
71k
Neural Spatial Audio Processing for Sound Field Analysis and Control
skoyamalab
0
290
Self-Hosted WebAssembly Runtime for Runtime-Neutral Checkpoint/Restore in Edge–Cloud Continuum
chikuwait
0
510
ラッコキーワード サービス紹介資料
rakko
1
3.2M
Bridging the Design Gap: How Collaborative Modelling removes blockers to flow between stakeholders and teams @FastFlow conf
baasie
0
540
[RailsConf 2023] Rails as a piece of cake
palkan
59
6.5k
Java REST API Framework Comparison - PWX 2021
mraible
34
9.3k
Lightning Talk: Beautiful Slides for Beginners
inesmontani
PRO
1
530
Chrome DevTools: State of the Union 2024 - Debugging React & Beyond
addyosmani
10
1.2k
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
12
1.1k
Learning to Love Humans: Emotional Interface Design
aarron
275
41k
Transcript
©MIXI TIPSTARを支える Cloud Spanner 2025/10/18 株式会社MIXI 若松丈人
©MIXI 2 自己紹介 2023年度に新卒として入社。 入社から2025年8月まで TIPSTAR のバックエンド開発・運用に携わる。 2025年8月から mixi2 のバックエンド開発
若松丈人 登録してね ->
©MIXI 会津若松
©MIXI 僕と親和性が高そうな土地ですね
©MIXI 5 今回お話しすること TIPSTAR を支える Cloud Spanner
©MIXI 6 TIPSTAR とは 全国の公営競技(競輪/オートレース)にネット投票できるサービス
©MIXI 7 Cloud Spanner とは NewSQL
©MIXI 8 New SQL とは RDB のトランザクション特性(ACID特性)を持ちながら NoSQL のように水平スケール可能なDB
©MIXI 9 なぜCloud Spannerが必要だったのか リリース前(開発初期)は Cloud SQL で開発されていたが、大量の r/w が予想されCloud
Spanner へ 1. 定常的なユーザーアクセスに伴う r/w(read メイン) 2. レースの度に数万〜数十万件のデータの r/w(write メイン) 朝のレース(8時30分ごろ)から深夜のレース(0時前後)まで 10〜20 分間隔で発生
©MIXI 10 なぜCloud Spannerが必要だったのか リリース前(開発初期)は Cloud SQL で開発されていたが、大量の r/w が予想されCloud
Spanner へ 1. 定常的なユーザーアクセスに伴う r/w(read メイン) 2. レースの度に数万〜数十万件のデータの r/w(write メイン) 朝のレース(8時30分ごろ)から深夜のレース(0時前後)まで 10〜20 分間隔で発生 2024年末に開催された競輪グランプリ(1年で1番大きいレース) - 発生したデータ書き込み:100万件以上 - 車券データ - ミッションデータ - ボーナスデータ - etc…
©MIXI Cloud Spanner すごい
©MIXI 12 なぜRDB だと水平スケールが難しい? RDB ・読み込み負荷:リードレプリカを増やして分散可能 ・書き込み負荷:マスター1台に集中
©MIXI 13 なぜRDB だと水平スケールが難しい? RDB ・読み込み負荷:リードレプリカを増やして分散可能 ・書き込み負荷:マスター1台に集中 書き込み用のノードを追加すると整合性を担保するための課題が発生 ・どの更新が最新なのか ・どのノードを正とするのか
©MIXI 14 なぜRDB だと水平スケールが難しい? RDB ・読み込み負荷:リードレプリカを増やして分散可能 ・書き込み負荷:マスター1台に集中 書き込み用のノードを追加すると整合性を担保するための課題が発生 ・どの更新が最新なのか ・どのノードを正とするのか
分散トランザクションなどで解決することも可能だが、運用が複雑に -> データの整合性の担保と水平スケールはトレードオフ
©MIXI 15 Spannerの仕組み Split ・テーブル全体をキー範囲で自動的に分割したもの ・各 Split 単位でディスク上に配置され、レプリカを持つ ・Split 単位で読み書き可能
CREATE TABLE Singers( SingerId INT64 NOT NULL PRIMARY KEY, FirstName STRING(1024), LastName STRING(1024), SingerInfo BYTES(MAX), ); 図引用元: Google Cloud 公式ドキュメント『Schema and Data Model』
©MIXI 16 Spannerの仕組み UPDATE Singers SET FirstName = “xxx” WHERE
SingerId = 1 Split A Zone A (Key 1–3) Application Spanner Server Split B Zone A (Key 4–5) Split A Zone B Split A Zone C Split B Zone B Split C Zone C
©MIXI 17 Spannerの仕組み UPDATE Singers SET FirstName = “xxx” WHERE
SingerId = 1 Split A Zone A (Key 1–3) Application Spanner Server Split A Zone B Split A Zone C 1. Leader が対象キー範囲にロックを取得 2. Leader が更新を follower にブロードキャスト 3. follower はロックを取得できたかをリーダーに返す 4. 全体で過半数のロックが取得できた場合、 Leader がコミット可能と判断
©MIXI 18 Spannerの仕組み TrueTime API 「現在時刻の不確実性( ±ε)」を含む時間範囲を返す Spanner は全てノード間で時間のズレが ±7ms
の範囲内に抑えられている。 → リーダーの Split が動作しているノードで取得した時刻 ±7ms の範囲内に、クラスタ内すべてのノードの実際 の時刻が収まっていることが保証されている ノードAの現在時刻 時間軸 ノードA ノードB ノードC ±7ms 以内 ノードBの現在時刻 ノードCの現在時刻
©MIXI 19 Spannerの仕組み TrueTime API で取得した時間範囲のうち最も未来の時間が経過してからコミットすることで どのノードから見ても「すでに確定済み」として見える → ノード間の整合性問題を解決 ノードAの現在時刻
時間軸 ノードA ノードB ノードC ±7ms 以内 ノードBの現在時刻 ノードCの現在時刻 コミット
©MIXI Cloud Spanner 面白そう https://techbookfest.org/product/2URkJbKFnJ9axX3vmmqNvK?productVariantID=8rXyaFRiBNwt9StPJFTk7c
©MIXI 興味を惹かれた方は直接見に来てください Welcome Dive into MIXI