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 バックエンドアーキテクチャ of アバターサービス
Search
cocone
May 08, 2023
Technology
0
340
cocone TECH TALK Vol.6 - Kotlin バックエンドアーキテクチャ of アバターサービス
cocone
May 08, 2023
Tweet
Share
More Decks by cocone
See All by cocone
20240301_cocone_EMゆるミートアップvol6_LT資料
cocone
0
420
2024_cocone-avatarservice.pdf
cocone
0
1.1k
2024_cocone-wellbeing
cocone
0
3.3k
2023夏季合同企業説明会ココネ
cocone
0
170
cocone TECH TALK Vol.6 - リアルタイム対戦xバックエンドアーキテクチャ
cocone
0
400
cocone TECH TALK Vol.6 - ココネグループのブロックチェーン MOOI Network とのバックエンド連携
cocone
0
320
ココネ株式会社 会社紹介
cocone
0
120k
cocone corporation(JPN)Letter for Designer
cocone
0
640
cocone corporation(JPN)/Handbook2022
cocone
1
30k
Other Decks in Technology
See All in Technology
Microsoft for Startups Founders Hub_20240429 update
daikikanemitsu
1
2.4k
KubeConにproposalを送りたい人へのアドバイス
sat
PRO
3
280
成長をサポートするピープルマネジメントのやり方
sioncojp
9
1.4k
IaCジェネレーターとBedrockで詳細設計書を生成してみた
tsukasa_ishimaru
4
940
同じ様なUIをiOS/Android間で合わせるヒントNo.2
fumiyasac0921
1
110
Microsoft Intune 勉強会 第 2 回目
tamaiyutaro
2
500
コードファーストの考え方。 Amplify Gen2から学ぶAWS次世代のWeb開発体験
yoshiitaka
2
520
EM完全に理解した と思ったけど、 やっぱり何も分からなかった話 / EM Night Fukuoka #1
hirutas
0
310
本当のガバクラ基礎
toru_kubota
0
140
LayerXにおけるLLMプロダクト開発の今までとこれから
layerx
PRO
4
1.3k
MixIT 2024 - Pulumi : Gérer son infra avec son langage de programmation préféré
ju_hnny5
1
120
Handling focus in 2024
tahia910
0
570
Featured
See All Featured
Ruby is Unlike a Banana
tanoku
96
10k
Fontdeck: Realign not Redesign
paulrobertlloyd
76
4.9k
Being A Developer After 40
akosma
67
580k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
21
1.6k
Done Done
chrislema
178
15k
KATA
mclloyd
16
12k
It's Worth the Effort
3n
180
27k
No one is an island. Learnings from fostering a developers community.
thoeni
16
2.1k
Why You Should Never Use an ORM
jnunemaker
PRO
51
8.7k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
66
14k
ParisWeb 2013: Learning to Love: Crash Course in Emotional UX Design
dotmariusz
104
6.6k
Designing on Purpose - Digital PM Summit 2013
jponch
111
6.5k
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サービスの技術が当たり前に構築されている • ちょっと罠があったりもするが概ね安定運営
ご清聴ありがとうございました このあとの懇親会もよろしくお ねがいします