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
cocone TECH TALK Vol.6 - Kotlin バックエンドアーキテクチャ o...
Search
cocone
May 08, 2023
Technology
0
600
cocone TECH TALK Vol.6 - Kotlin バックエンドアーキテクチャ of アバターサービス
cocone
May 08, 2023
Tweet
Share
More Decks by cocone
See All by cocone
Cocone_Research_Center_2025.pdf
cocone
0
250
20240301_cocone_EMゆるミートアップvol6_LT資料
cocone
0
920
2024_cocone-wellbeing
cocone
0
5k
2023夏季合同企業説明会ココネ
cocone
0
390
cocone TECH TALK Vol.6 - リアルタイム対戦xバックエンドアーキテクチャ
cocone
0
660
cocone TECH TALK Vol.6 - ココネグループのブロックチェーン MOOI Network とのバックエンド連携
cocone
0
570
cocone corporation(JPN)/Handbook2022
cocone
1
30k
cocone Tech Talk vol.5 - Unity Dotsを使ってみた
cocone
0
2.5k
cocone corporation(JPN)/Letter to Planner
cocone
0
560
Other Decks in Technology
See All in Technology
Agentic Codingの実践とチームで導入するための工夫
lycorptech_jp
PRO
0
410
Oracle Cloud Infrastructure:2026年2月度サービス・アップデート
oracle4engineer
PRO
0
220
LLM活用の壁を超える:リクルートR&Dの戦略と打ち手
recruitengineers
PRO
1
240
Master Dataグループ紹介資料
sansan33
PRO
1
4.4k
どこで打鍵するのが良い? IaCの実行基盤選定について
nrinetcom
PRO
2
170
メタデータ同期に潜んでいた問題 〜 Cache Stampede 時の Cycle Wait を⾒つけた話
lycorptech_jp
PRO
0
150
Introduction to Sansan Meishi Maker Development Engineer
sansan33
PRO
0
360
問い合わせ自動化の技術的挑戦
recruitengineers
PRO
2
150
Webアクセシビリティ技術と実装の実際
tomokusaba
0
210
LINEヤフーにおけるAI駆動開発組織のプロデュース施策
lycorptech_jp
PRO
0
400
大規模サービスにおける レガシーコードからReactへの移行
magicpod
1
130
Agentic Software Modernization - Back to the Roots (Zürich Agentic Coding and Architectures, März 2026)
feststelltaste
1
170
Featured
See All Featured
A Soul's Torment
seathinner
5
2.4k
What Being in a Rock Band Can Teach Us About Real World SEO
427marketing
0
190
16th Malabo Montpellier Forum Presentation
akademiya2063
PRO
0
63
Designing for Performance
lara
611
70k
Bioeconomy Workshop: Dr. Julius Ecuru, Opportunities for a Bioeconomy in West Africa
akademiya2063
PRO
1
68
SEO for Brand Visibility & Recognition
aleyda
0
4.3k
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
4.2k
Chasing Engaging Ingredients in Design
codingconduct
0
130
A Guide to Academic Writing Using Generative AI - A Workshop
ks91
PRO
0
230
Effective software design: The role of men in debugging patriarchy in IT @ Voxxed Days AMS
baasie
0
240
Building Flexible Design Systems
yeseniaperezcruz
330
40k
JavaScript: Past, Present, and Future - NDC Porto 2020
reverentgeek
52
5.9k
Transcript
Kotlin バックエンドアーキテク チャ of アバターサービス 2023/04 大友 秀輔
自己紹介 • 大友秀輔 (@slumbers99) • 2013年9月ココネ入社(子会社含 ◦ メッセンジャー ▪ Connect
▪ TonTon ▪ Potto ◦ アバター ▪ ポケコロ • ココネッツ ▪ ClawKiss ◦ 音声ライブ配信 ▪ 私を布教して
自己紹介 • 大友秀輔 • @slumbers99 • 2013年9月ココネ入社 ◦ メッセンジャー ▪
Connect ▪ TonTon ▪ Potto ◦ アバター ▪ ポケコロ • ココネッツ ▪ ClawKiss ◦ 音声ライブ配信 ▪ 私を布教して
今日話すこと • ClawKissとは • ClawKissでのバックエンドアーキテクチャ ◦ 使ったクラウドサービス ◦ 技術構成 ◦
苦労したところ • まとめ • 質疑応答
今日話さないこと • ChatGPT
ClawKissとは
ClawKiss とは • 2022年12月20日リリース • 可愛く遊んで、稼げる。Dress & Earn を謳ったココネがグローバル に挑戦するためのweb3サービス
• ブロックチェーンネットワーク 「MOOI」を利用 ◦ MOOIはココネグループが運用 • ココネが得意なCCPジャンルをブ ロックチェーンに載せたらどうなるか の意欲作
None
バックエンドアーキテクチャ
言語とフレームワーク • Kotlin 1.6.x ◦ JDK: Amazon Corretto 17 •
SpringBoot 2.6.x ◦ grpc-spring-boot-starter 4.7.x • gRPC ◦ protoc ver.3 • Gradle 7.4.x
DB系 - MongoDB Atlas (on aws) - ユーザーデータ - マスターデータ
- ElastiCache - リモートキャッシュ - OpenSearch - 全文検索
認証とモバイルPUSH • Firebase Authentication ◦ メール / パスワード ◦ Twitter
◦ Facebook ◦ Apple ◦ Google • Firebase Cloud Messaging ◦ 友達申請 ◦ 行動可能時間 ◦ お知らせ ◦ etc …
その他 • aws ◦ EC2 (ALB, EC2, AutoScaling Group …)
◦ S3 ◦ CodeDeploy ◦ Lambda (Python 3.8) ◦ API Gateway ◦ CloudFront ◦ Systems Manager (パラ メータストア) • Simple Notification Service • Jenkins • DataDog • Gitlab
None
環境 • Alpha, Staging, Beta, Production 環境を用意 ◦ Application Server
以外は2分割 ◦ Alpha: 開発用、Staging: QA環境、Beta: リリース前確認 ◦ 開発用クライアントからはそれぞれ接続できるようにしてる ◦ S3などもそれぞれ別に用意 • 各種DB接続先などパラメータストアで保持 ◦ AutoScaling時に環境変数へコピー
デプロイ Merge RequestでKotestとDetektのチェックが 通ったものをリリースブランチにマージ kotlin proto gradle build pull
デプロイ • リリースブランチに対してMR ◦ Jenkinsに投げてKotestとDetekt実行 ▪ Jenkinsプラグイン ▪ PUSHとMR作成時に実行 ◦
結果をGitlabのMRのステータス更新 ▪ Pipelines must succeed の設定にしている • Jenkinsでデプロイジョブを実行 ◦ リリースブランチをPULLしてビルド ◦ CodeDeployを実行
苦労したところ
苦労したところ • gRPC を使っての環境構築が初めてだった ◦ ALBのヘルスチェックが通らない問題 ◦ ローカルでのgRPC接続はできる ◦ デプロイしてみてもヘルスチェックのログすら記録されない
◦ ヘルスチェックは虚無にいったのか?? ◦ tcpdumpとってみた -> 解決の糸口
苦労したところ • HTTP2を許可するだけだった・・・ ◦ 会社テックブログに載せました「Spring BootとgRPCをApplication Load Balancer(ALB)で動かそうとしてハマったこと」 ◦ https://engineering.cocone.io/2022/06/10/run_springboot_
and_grpc_with_alb/
苦労したところ • protoファイルどこに置こうか問題 ◦ protoは別リポジトリで管理 ◦ submoduleにして参照していた ◦ なんとなくうまく行っているがこれでいいかわからん •
基本的にprotoリポジトリはブランチ一本化 ◦ developブランチ(なんでもいいけど)に落ち着いた • 構造体からパラメータ消すとそもそもビルドできなくなる ◦ 消すときのルールは必要かも
苦労したこと その他特に困ったこともなく、比較的安定して運用できております。 バグは・・・・すいません。
まとめ • ClawKissはAWSふんだんにつかわれている • Kotlin on SpringBoot はいい選択肢だと思っている • アバターサービスと銘打って入るがバックエンドとしては特に尖ったことは
していない • 当たり前のWEBサービスの技術が当たり前に構築されている • ちょっと罠があったりもするが概ね安定運営
ご清聴ありがとうございました このあとの懇親会もよろしくお ねがいします