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
Startup Issue Gym#3 -ネットワーク同期システムの置き換えで直面した課題
Search
whisky_shusuky
December 16, 2021
Programming
0
500
Startup Issue Gym#3 -ネットワーク同期システムの置き換えで直面した課題
こちらの登壇資料です
https://startup-issue-gym.connpass.com/event/229549/
whisky_shusuky
December 16, 2021
Tweet
Share
Other Decks in Programming
See All in Programming
dbtのドメイン分割による データ基盤の改善とDigdagとの連携
sakama
0
440
Milestoner
bkuhlmann
1
410
FigmaとPHPで作る1ミリたりとも表示崩れしない最強の帳票印刷ソリューション
ttskch
43
19k
"config" ってなんだ? / What is "config"?
okashoi
0
250
VS Code をプロダクトにどう取り込むか
onomax
1
650
検証も兼ねて個人開発でHonoとかと向き合った話
hanetsuki
1
1.3k
Snowflakeで眠ったデータを起こそう!
estie
0
140
サイコロで理解する統計的仮説検定の考え方
tatamiya
4
1k
Fragment Composition of GraphQL
quramy
13
1.4k
Sheets API使ってみた
toshi0383
2
160
MetricKitで予期せぬ終了を検知する話 / Detect unexpected termination with MetricKit
nekowen
1
200
PHP8.3の機能を振り返る / Review of PHP 8.3 features
seike460
PRO
1
120
Featured
See All Featured
Writing Fast Ruby
sferik
622
60k
Building Applications with DynamoDB
mza
88
5.6k
Ruby is Unlike a Banana
tanoku
96
10k
The Success of Rails: Ensuring Growth for the Next 100 Years
eileencodes
33
6k
Scaling GitHub
holman
457
140k
The Pragmatic Product Professional
lauravandoore
26
5.8k
A better future with KSS
kneath
231
16k
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
155
14k
Into the Great Unknown - MozCon
thekraken
14
1k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
352
28k
Stop Working from a Prison Cell
hatefulcrawdad
267
19k
GraphQLとの向き合い方2022年版
quramy
33
12k
Transcript
CONFIDENTIAL ©2021 Synamon Inc. ネットワーク同期システムの置き換えで直面した課題 2021年12月3日
CONFIDENTIAL ©2021 Synamon Inc. 会社紹介 2 ToB向けのXR(VR/AR)のソリューションを提供している企業になります VR(非現実空間を構成) AR(現実空間に投影)
CONFIDENTIAL ©2021 Synamon Inc. 会社紹介 3 VR/AR/MR企画・開発のSynamonと三 井住友海上が「VR事故車損害調査研 修」を共同開発
運営しているプラットフォームのNEUTRANSを 使用して事故車損害調査研修をVR空間で提 供しました。
CONFIDENTIAL ©2021 Synamon Inc. 会社紹介 4 現在ではNEUTRANSにこだわらずXR全般 (VR/AR)のソリューションを提供しています。 案件は紹介できませんがVarjoという高性能
VR/AR機器を使った体験会もやっていますの で興味有る方はご来社頂ければ体験できま す。 Synamon、フィンランドの高性能 VR/XRハードウェアVarjoの「Software Partner Program」に参画
CONFIDENTIAL ©2021 Synamon Inc. 自己紹介 うぃすきー(@whisky_shusuky) 文系大学 ↓ オンプレインフラエンジニア
データセンターに行って結線とかしてた ↓ ブログのプラットフォームの会社(Perl/Rails/Go) 2018年頃VRで遊ぶ動画をYoutubeで見かけてハマる ↓ SYNAMON 2021年1月入社 NEUTRANSがRailsを使っていたため応募した インフラ・バックエンド・フロントエンドとWeb周り全般を対応 5
CONFIDENTIAL ©2021 Synamon Inc. ネットワーク機能を置き換えられないか実験 NEUTRANSではネットワーク同期エンジンとしてPhotoCloudを使用し ている。アバターの手の動作などをクライアント間で同期するために使 用している。 ↓
入社したら別のエンジンのDiarkisに置き換えられないか実験していた。 6
CONFIDENTIAL ©2021 Synamon Inc. ネットワーク機能を置き換えられないか実験 サーバーの開発言語がGoで社内で Goを書けるのが私だけだったので入 社直後だったけど急遽対応した 7
CONFIDENTIAL ©2021 Synamon Inc. - 30人→100人接続人数増加させることができ るとのことでDiarkisの検証を行った - デフォルトでhttpサーバー経由でルーム作成
ができる - 既存のバックエンドとマイクロサービス的 に連携できた - カスタム実装も可能でルーム内の人数を 確認するAPIなどを自前で作成できた - UDPサーバーも自前で実装できる - クライアント間での同期用途でunixtime を返す機能を実装した - k8sでオートスケール設定できる Diarkis Diarkisの使用感 8 HTTP UDP 既存バックエンド (AWS Fargate) Unityクライ アント
CONFIDENTIAL ©2021 Synamon Inc. だが、、、 要件の問題でk8sを使えなかった 9
CONFIDENTIAL ©2021 Synamon Inc. - Unityクライアントからはルームが有るUDP サーバーのpublic ipに接続する -
Diarkisの仕様でk8sを使用するとipやportが変 動する - これは通常のオンラインゲーム開発などで家庭 からつなぐのであれば特に問題ない Diarkis k8sで問題が有った業務要件 10 UDP UDP Unityクライ アント ルーム 家庭
CONFIDENTIAL ©2021 Synamon Inc. - 弊社の顧客は大企業が多い - そのため社外への接続にはホワイトリストを設 定しているところが多い
- そのため全てのipやportに関するホワイトリスト をかけて欲しいと顧客に依頼することになって しまいマズイという話になった - 一般的なオンラインゲーム開発などのC向けの 製品では問題にならない部分でトラブルが発生 した Diarkis k8sで問題が有った業務要件 11 UDP UDP Unityクライ アント 企業NW ホワイトリスト ルーム
CONFIDENTIAL ©2021 Synamon Inc. - k8sは使わない - スケールアウトする度にEC2インスタン スを増やす形で対応
- UDPサーバーが増加する度にRoute53 にてudp-*.sample.com:8000の形式で UDPサーバーへ接続されるAレコードを 追加する Diarkis 対応策 12 UDP2 Route53 udp-1.sample.com:8000 A UDP1のIP udp-2.sample.com:8000 A UDP2のIP UDP1
CONFIDENTIAL ©2021 Synamon Inc. 企業NW - 顧客にはudp-*.sample.com:8000のホ ワイトリストのみ追加で開けるように依頼 する
Diarkis 対応策 13 UDP2 Unityクライ アント ホワイトリスト udp-1.sample.com:8000へのUDPを許可 Route53 udp-1.sample.com:8000 A UDP1のIP udp-2.sample.com:8000 A UDP2のIP UDP1
CONFIDENTIAL ©2021 Synamon Inc. まとめ - Diarkis自体は自由度高く開発できる - NEUTRANS以外のToC案件があればk8sを使ってオートス
ケールするようにも対応できるであろう 14
CONFIDENTIAL ©2021 Synamon Inc. 採用 採用募集中です! WantedlyでSYNAMONで検索! 15 Meetyで質問・相談も受け付けてま
す!
None