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
スマホゲームサーバーのしくみをしってみよう
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Takuma Kajikawa
October 29, 2018
Programming
16k
6
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
スマホゲームサーバーのしくみをしってみよう
【サポーターズCoLab勉強会】「スマホゲームサーバーのしくみをしってみよう」の登壇資料です。
Takuma Kajikawa
October 29, 2018
More Decks by Takuma Kajikawa
See All by Takuma Kajikawa
代数的データ型って何が嬉しいの? #frontend_phpcon_do
kajitack
8
3.7k
要はバランスからの卒業 #yumemi_grow
kajitack
2
220
ソフトウェア設計の結合バランス #phperkaigi
kajitack
0
630
ドメインイベントでビジネスロジックを解きほぐす #phpcon_odawara
kajitack
4
960
実践ハーネスエンジニアリング #MOSHTech
kajitack
7
7.3k
メッセージングを利用して時間的結合を分離しよう #phperkaigi
kajitack
3
700
TechTrain開発 x AI #CircLeT
kajitack
0
100
コードレビューをしない選択 #でぃーぷらすトウキョウ
kajitack
3
1.5k
あなたはユーザーではない #PdENight
kajitack
4
480
Other Decks in Programming
See All in Programming
並列実装の現場、2ヶ月間実務でAIを使い倒したAIもPCも私も限界が近い
ming_ayami
0
130
そのテスト、説明できますか?~LWテスト戦略FW~のご紹介
nakahara
0
120
Creating Composable Callables in Contemporary C++
rollbear
0
130
IBM Bobを活用したレガシーアプリの最新化
oniak3ibm
PRO
1
200
jQueryをバージョンアップする前に使いたいjQuery Migrate
matsuo_atsushi
0
500
キャリア迷子上等 ─ "ない道"は自分で作ればいい
16bitidol
3
2.1k
依存関係から依存物へ―Dependencyという言葉の歴史をひも解く
j_lee
0
120
AIで効率化できた業務・日常
ochtum
0
130
Developing with AI Agents — Codex, Claude Code & Cowork Practical Guide
x5gtrn
PRO
0
1.3k
肥大化するレガシーコードに立ち向かうためのインターフェース分離と依存の逆転 / JJUG CCC 2026 Spring
hirokunimaeta
0
550
その問い、本当に正しいですか?AI時代のエンジニアに必要な哲学と認知科学 / ai-philosophy-cognitive-science
minodriven
8
4.8k
ユニットテストの先へ:テスト技法で要求・仕様を整理するJava開発実践 / Beyond_Unit_Testing_Practical_Java_Development_Techniques_for_Organizing_Requirements_and_Specifications
shimashima35
0
400
Featured
See All Featured
How to Talk to Developers About Accessibility
jct
2
230
What Being in a Rock Band Can Teach Us About Real World SEO
427marketing
0
250
Testing 201, or: Great Expectations
jmmastey
46
8.2k
The innovator’s Mindset - Leading Through an Era of Exponential Change - McGill University 2025
jdejongh
PRO
1
200
A Soul's Torment
seathinner
6
2.9k
Design of three-dimensional binary manipulators for pick-and-place task avoiding obstacles (IECON2024)
konakalab
0
460
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.4k
Building Applications with DynamoDB
mza
96
7.1k
Leveraging LLMs for student feedback in introductory data science courses - posit::conf(2025)
minecr
1
280
Dominate Local Search Results - an insider guide to GBP, reviews, and Local SEO
greggifford
PRO
0
190
HTML-Aware ERB: The Path to Reactive Rendering @ RubyCon 2026, Rimini, Italy
marcoroth
1
190
Principles of Awesome APIs and How to Build Them.
keavy
128
18k
Transcript
スマホゲームサーバの しくみをしってみよう Takuma Kajikawa 2018/10/29 サポーターズ CoLab
梶川琢⾺ Takuma Kajikawa - 2016卒 - モバイルゲーム開発会社 - サーバーエンジニア 3年⽬
過去の発表 - MySQLの基礎 - DBテーブル設計入門 - オンラインゲームのしくみをしってみよう
もくじ - スマホゲームの特徴 - システム構成例と通信の流れ - ゲームの開発・運用で気をつけるべきこと
スマホゲームの特徴
スマホゲームのゲームサイクル - キャラ育成 → バトル/クエスト → キャラ育成 →.. - シングル
+ マルチプレイモード - マルチプレイではよりリアルタイム性が求められる
課金モデル - 無料 + アプリ内課金 - ガチャ、スタミナ回復、時短など - 高可用性が求められる -
ガチャが引きたい時に引けない… - せっかく時短したのにサーバー障害…
スマホゲームサーバの特徴 - 大量のアクセス - データ更新頻度が高い - ピーク時と平常時に求められる性能の差が大きい - メンテナンスをなるべくしない -
頻繁にコンテンツや機能の追加
データの特徴 - ユーザデータ - ユーザのレベルや所持アイテム、所持金など - マスタデータ - ゲームのステージやキャラなどの運営が管理するデータ -
ログデータ - KPI分析や障害調査
システム構成・処理の流れ
ゲームモードで変わるシステム構成 - アウトゲーム - キャラ育成、ガチャ、バトル開始、終了など - HTTP(S)通信 - Webアプリの構成に近い
ゲームモードで変わるシステム構成 - インゲーム(マルチプレイ) - バトル中の味方や敵の位置、攻撃、チャットなど - WebSocketやP2Pなどの双方向通信
API サーバー DB サーバー KVS サーバー Log サーバー LB アウトゲームのサーバー構成
CDN Asset サーバー
APIサーバ - リクエスト先はロードバランサによって決まる - 一般的なWebアプリのAPIと同じ構成 - Apache/Nginx - PHP/Java/Go など
APIサーバ - スケールアウト・スケールインを柔軟に - ピーク時と平常時に求められる性能の差が大きい - 機能ごとに分割したサーバーを用意することもある - 課金、認証、マッチングなど -
特定の機能に特化することで、開発に専念
データストア - DB (MySQLやPostgreSQLなど) - 永続化データ - KVS (RedisやMemcachedなど) -
キャッシュ、アクセス頻度が高く消えても問題ない - ログ(BigQueryなど) - 分析用のデータ
アセットサーバー - 静的ファイルの配信用のサーバー - 画像や音楽、3Dモデルなど - CDNでキャッシュさせる - 新バージョンだったらクライアントがリクエストする
アウトゲームの処理の流れ - 画面遷移時やデータ更新時にサーバーにリクエスト - サーバーがDBやKVSのデータを取得、更新 - 一度のリクエストでデータの追加や更新、取得 - リクエストメソッドの使い分けはほぼGETかPOST -
× RESTful API
アセット取得の流れ - アセットの種別ごとにバージョンを管理するDBを用意 - 新しいアセットをデプロイしたらDBのバージョンを上げる - クライアントがアセットのバージョンを確認するリクエスト をする - サーバーはDBのバージョンを返す
- クライアントで保持しているバージョンと違うアセットがあっ たらそのアセットをダウンロード
インゲーム (C/S方式) Battle サーバー DB サーバー KVS サーバー Log サーバー
Battleサーバー - 接続先はバトル開始前にAPIサーバーで割り振られる - リアルタイム性が求められる - WebSocketやリアルタイムゲームエンジン - C++/Node.js/Go など
- サーバー集中型とクライアント分散型 - ゲームによって特色がある
サーバー集中型 - サーバー側でゲームロジックや進行を行う - バトル中サーバー側で必要なデータを保持しておく - 端末間でズレるとまずい処理 - 対戦ゲームでのキャラの位置や当たり判定 -
協力バトルのボスの位置やHP - サーバーの判定処理を待つ必要がある
クライアント分散型 - それぞれの端末でゲームの進行を行う - ゲーム進行上、端末間のズレが気にならない場合 - 協力バトルの雑魚敵の位置はズレても気にならない - 不正対策はしづらい -
擬似的なP2P、パケットのブロードキャストに専念する
インゲームの処理 パーティを組んで戦うアクションバトルの例 1. パーティ作成 or 参加 2. ルーム(バトル空間)を作成、バトル開始 3. ルーム内でバトル
4. バトル終了、ルーム削除、パーティ解散
ルーム入場からバトル開始まで 1. CL → API: パーティ参加リクエスト 2. API → DB:
パーティがあるか確認、なければ作成 3. API → CL: Battleサーバーの接続先を返す 4. CL → Battle: ルーム作成リクエスト 5. CL → API: Battle開始
バトル中 1. CL → Battle: コマンドを送信 2. Battle → CL:
バトル情報を返す 3. Battle → CL: イベント発生を通知
バトル終了 1. CL → Battle: バトル終了リクエスト 2. Battle → CL:
ルームを削除し、切断 3. CL → API: リザルトのリクエスト 4. CL → API: パーティを解散
その他、運営に必要なシステム - レポジトリサーバー、デプロイサーバー - ソースコードやアセットの管理、デプロイに使う - 運営やカスタマーサポート用の管理ツール - データの確認、お知らせやバナーの反映、補填など -
KPI基盤 - ログデータの分析や可視化、社内共通
運用・開発で 気をつけるべきこと
DBの負荷を考慮しよう - DBが負荷のボトルネックになりがち - オンラインでスキーマの変更がし辛い - インデックスやDBのパーティショニング - 集計データはバッチ処理して、キャッシュさせる -
なるべく少ないクエリ数でデータを取得
DBの負荷分散 - 水平分割 - ユーザのIDごとにDBサーバを振り分ける - 期間限定のDBを日付でパーティショニング - Master/Slave構成 -
マネージドサービスを使うのもあり
オンラインメンテ - DBのデータ設計を変えたときや定期メンテをオンライン でやりたい - Master DBがネック - Master/Slave切り替え -
Percona Tool Kit Online Schema Change(MySQL) - マネージドサービスを使うのもあり
リリース後のアラート監視 - サーバーが止まる前に対処する - 各種サーバーのエラー、CPU使用率、リクエスト数 - DBサーバーのクエリ数 - レスポンスタイム -
Disk write、使用量 - お客様の問い合わせ、Twitterでエゴサ
ゲーム運用で便利なツールを作る - データ管理のしくみを作ろう - ExcelやスプレッドシートからSQLへの変換 - デバッグ機能や管理ツールを作ろう - 開発スピードが格段に上がる -
管理ツールの権限管理は重要
まとめ
まとめ - ゲームのシステム構成は基本的にはWebアプリと一緒 - アクセス数や更新頻度が高くなる傾向 - リアルタイム性の求められるシステム構成はゲームによっ て異なる - 高い可用性を保つためにオンラインメンテ、アラート監
視などの工夫が必要
ご清聴ありがとうございました!