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
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
MIXI ENGINEERS
PRO
October 18, 2025
Technology
69
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
70
法務DXの最前線: ゼロからのAI導入とバックオフィスの変革 ~ 46の施策で検証した「コスト」と「リードタイム」削減の裏側 ~
mixi_engineers
PRO
0
31
AIで有人対応の品質チェックを"同じ物差し"に:CSの評価軸設計とプロンプト調整
mixi_engineers
PRO
0
25
AI活用を“個人技”で終わらせない ― 現場の自律性と成果を両立させた推進の裏側 ―
mixi_engineers
PRO
1
56
投資プロセス全体の再設計:投資先データ活用の取り組み
mixi_engineers
PRO
0
28
AI推進委員会とGemini Enterpriseが牽引する全社AI活用とナレッジ活用基盤の刷新
mixi_engineers
PRO
0
91
「プロンプトって何?」から始まった1年。 監査メソドロジーへのAIアシスタント実装と組織変革の記録
mixi_engineers
PRO
0
29
365日挑んだ、デザイナーAI活用・実務事例!圧倒的ボリュームで大公開
mixi_engineers
PRO
0
44
AIを前提に再設計する、採用プロセスの変革
mixi_engineers
PRO
0
36
Other Decks in Technology
See All in Technology
デシリアライゼーションを理解する / Inside Deserialization
tomzoh
0
240
サイバーフィジカル社会とは何か / What Is a Cyber-Physical Society?
ks91
PRO
0
160
NgRx SignalStore: The Power of Extensibility
rainerhahnekamp
0
190
あるアーキテクチャ決定と その結果/architecture-decision-and-its-result
hanhan1978
2
570
ログ基盤・プラグイン・ダッシュボード、全部整えた。でも最後は人だった。
makikub
5
1.4k
CC Workflow Studio
seiyakobayashi
0
270
ある製造業の会社全体のAI化に1エンジニアが挑んだ話
kitami
2
850
さくらのAI Engineから始める クラウドネイティブ意識
melonps
0
140
Contract One Engineering Unit 紹介資料
sansan33
PRO
0
16k
プロンプトエンジニアリングを超えて:自由と統制のあいだでつくる Platform × Context Engineering
yuriemori
0
170
Introduction to Sansan Meishi Maker Development Engineer
sansan33
PRO
0
380
ADOTで始めるサーバレスアーキテクチャのオブザーバビリティ
alchemy1115
2
270
Featured
See All Featured
The Psychology of Web Performance [Beyond Tellerrand 2023]
tammyeverts
49
3.4k
GraphQLとの向き合い方2022年版
quramy
50
14k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
31
2.7k
Dominate Local Search Results - an insider guide to GBP, reviews, and Local SEO
greggifford
PRO
0
130
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
16
1.9k
Building AI with AI
inesmontani
PRO
1
870
HU Berlin: Industrial-Strength Natural Language Processing with spaCy and Prodigy
inesmontani
PRO
0
310
Building a Scalable Design System with Sketch
lauravandoore
463
34k
GraphQLの誤解/rethinking-graphql
sonatard
75
12k
Embracing the Ebb and Flow
colly
88
5k
Technical Leadership for Architectural Decision Making
baasie
3
320
The Limits of Empathy - UXLibs8
cassininazir
1
290
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