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
430
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
730
2024_cocone-avatarservice.pdf
cocone
0
2k
2024_cocone-wellbeing
cocone
0
4.5k
2023夏季合同企業説明会ココネ
cocone
0
260
cocone TECH TALK Vol.6 - リアルタイム対戦xバックエンドアーキテクチャ
cocone
0
490
cocone TECH TALK Vol.6 - ココネグループのブロックチェーン MOOI Network とのバックエンド連携
cocone
0
410
ココネ株式会社 会社紹介
cocone
0
130k
cocone corporation(JPN)Letter for Designer
cocone
0
670
cocone corporation(JPN)/Handbook2022
cocone
1
30k
Other Decks in Technology
See All in Technology
WACATE2024冬セッション資料(ユーザビリティ)
scarletplover
0
330
プロダクト開発を加速させるためのQA文化の築き方 / How to build QA culture to accelerate product development
mii3king
1
290
普通のエンジニアがLaravelコアチームメンバーになるまで
avosalmon
0
120
DUSt3R, MASt3R, MASt3R-SfM にみる3D基盤モデル
spatial_ai_network
2
270
TSKaigi 2024 の登壇から広がったコミュニティ活動について
tsukuha
0
170
AWS環境におけるランサムウェア攻撃対策の設計
nrinetcom
PRO
0
170
[JAWS-UG新潟#20] re:Invent2024 -CloudOperationsアップデートについて-
shintaro_fukatsu
0
120
Opcodeを読んでいたら何故かphp-srcを読んでいた話
murashotaro
0
320
NW-JAWS #14 re:Invent 2024(予選落ち含)で 発表された推しアップデートについて
nagisa53
0
280
型情報を用いたLintでコード品質を向上させる
sansantech
PRO
2
140
サーバーなしでWordPress運用、できますよ。
sogaoh
PRO
0
120
宇宙ベンチャーにおける最近の情シス取り組みについて
axelmizu
0
120
Featured
See All Featured
Facilitating Awesome Meetings
lara
50
6.1k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
26
1.5k
Rails Girls Zürich Keynote
gr2m
94
13k
Reflections from 52 weeks, 52 projects
jeffersonlam
347
20k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
6
450
Fashionably flexible responsive web design (full day workshop)
malarkey
405
66k
[RailsConf 2023] Rails as a piece of cake
palkan
53
5.1k
StorybookのUI Testing Handbookを読んだ
zakiyama
27
5.4k
Building a Modern Day E-commerce SEO Strategy
aleyda
38
7k
Agile that works and the tools we love
rasmusluckow
328
21k
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
26
1.9k
Code Review Best Practice
trishagee
65
17k
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サービスの技術が当たり前に構築されている • ちょっと罠があったりもするが概ね安定運営
ご清聴ありがとうございました このあとの懇親会もよろしくお ねがいします