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
Yuta Shimakawa
March 08, 2023
Technology
2
3k
モノレポによるマイクロサービスアーキテクチャの開発運用
マイクロサービスのコードベース管理手法の一つであるモノレポによる開発のメリット・デメリットに触れつつ、実際の開発現場における運用上の工夫について紹介します
Yuta Shimakawa
March 08, 2023
Tweet
Share
More Decks by Yuta Shimakawa
See All by Yuta Shimakawa
現場のデータを集める技術
bananaumai
0
130
Build real world data collecting architecture with Goroutine and Channel
bananaumai
1
650
Other Decks in Technology
See All in Technology
DUSt3R, MASt3R, MASt3R-SfM にみる3D基盤モデル
spatial_ai_network
2
230
Storage Browser for Amazon S3
miu_crescent
1
290
メンタル面でもつよつよエンジニアになる/登壇資料(井田 献一朗)
hacobu
0
100
1等無人航空機操縦士一発試験 合格までの道のり ドローンミートアップ@大阪 2024/12/18
excdinc
0
180
どちらを使う?GitHub or Azure DevOps Ver. 24H2
kkamegawa
0
1.1k
Fanstaの1年を大解剖! 一人SREはどこまでできるのか!?
syossan27
2
180
Yahoo! ズバトクにおけるフロントエンド開発
lycorptech_jp
PRO
0
100
サイボウズフロントエンドエキスパートチームについて / FrontendExpert Team
cybozuinsideout
PRO
5
38k
Working as a Server-side Engineer at LY Corporation
lycorp_recruit_jp
0
350
NilAway による静的解析で「10 億ドル」を節約する #kyotogo / Kyoto Go 56th
ytaka23
3
380
【re:Invent 2024 アプデ】 Prompt Routing の紹介
champ
0
160
社内イベント管理システムを1週間でAKSからACAに移行した話し
shingo_kawahara
0
200
Featured
See All Featured
How to train your dragon (web standard)
notwaldorf
88
5.7k
Thoughts on Productivity
jonyablonski
68
4.4k
Put a Button on it: Removing Barriers to Going Fast.
kastner
59
3.6k
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
17
2.3k
Docker and Python
trallard
42
3.1k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
6
450
Fashionably flexible responsive web design (full day workshop)
malarkey
405
66k
Adopting Sorbet at Scale
ufuk
73
9.1k
[RailsConf 2023] Rails as a piece of cake
palkan
53
5k
Into the Great Unknown - MozCon
thekraken
33
1.5k
Embracing the Ebb and Flow
colly
84
4.5k
Learning to Love Humans: Emotional Interface Design
aarron
274
40k
Transcript
© 2023 MODE, Inc. モノレポによる マイクロサービスアーキテクチャの開発運用 MODE, Inc. YUTA Shimakawa
1 2023/03/09 "良い開発者体験"にむけた国内/海外のアーキテクチャLT会 AWS編
© 2023 MODE, Inc. • SWE in the tech industry
for 10+ years • Joined MODE, Inc. 2019 • Backend & DevOps • SNS ◦ Twitter: @banana_umai ◦ GitHub: @bananaumai ◦ LinkedIn: Yuta Shimakawa YUTA Shimakawa 島川 悠太 Yuta Shimakawa 2
© 2023 MODE, Inc. MODE, Inc. 拠点:シリコンバレー、東京 2014年〜 シリコンバレー 2017年〜
東京 創業者:上田 学 /イーサン・カン 3 センサーからデータ集めて可視化・分析するた めの技術を軸に、現実世界のビジネス業務を改 善するためのIoT * DXなソリューションを提供
© 2023 MODE, Inc. 4 マイクロサービスアーキテクチャ
© 2023 MODE, Inc. 5 モノレポ • マイクロサービスのソースコードの管理手法の一つ • 各サービスを一つのソースコードリポジトリで管理する
• 反対はサービス毎にリポジトリを分ける • 日本だと比較的事例が少なめ(?) • アメリカのTech系スタートアップの界隈だと議論になりがち(らしい) • 某米検索最大手出身者が創業した会社ではモノレポが採用されがち(らしい)
© 2023 MODE, Inc. 6 • サービスの一覧性を高くしやすい • 開発に必要なサービス一式を立ち上げやすい •
同一言語で実装している場合、共通ライブラリの運用がしやすい • 複数のサービスやライブラリのコードを同一目的で変更しやすい • ハード/ソフトな共通化がしやすい(設定、デプロイ、規約など) モノレポのメリット
© 2023 MODE, Inc. 7 モノレポのデメリット • CICDパイプラインの構築に工夫が必要になりがち ◦ 工夫しないとCICDプロセスが鈍重になりやすい
◦ モノレポの構成自体にベストプラクティスがあるわけではないので、 すぐに使えるテンプレート的なCICDワークフローがない • モノレポに関わる人数や組織の構造によっては難しくなりがち(コンフリ クトの増加やブランチ管理の煩雑化など)
© 2023 MODE, Inc. 8 CICDパイプラインの工夫 ECR CodePipeline ECS AWS
GitHub Action push container images trigger pipeline • GHAでcontainer imageをbuild -> ECRにpush -> CodePipelineをトリガー • GHA WorkflowとAWS CodePipelineはサービス * 環境毎に作成 • mainブランチへのマージ時にサービスのコードに影響があればサンドボックス環境に自動デプロイ • ステージング及び本番デプロイについてはGit Tagを用いてデプロイワークフローをトリガーする
© 2023 MODE, Inc. 9 モノレポ管理の工夫 • 複雑なブランチ運用や長期ブランチを避ける(feature flagなど) •
モノレポで「あらゆるコード」を管理すべきか? ◦ NO ◦ 関連性が少ないコードは別リポジトリで分けている ◦ 例)ゲートウェイやモバイルアプリは別リポジトリで管理
© 2023 MODE, Inc. 10 所管・まとめ • 同一言語でバックエンドのマイクロサービスを構築する場合、モノレポは悪くな い選択肢 •
CICDパイプラインの管理やブランチ管理などには工夫が必要 • 似たような経験・知見・アドバイス・悩みがある方は是非お話ししましょう ◦ Twitter: @banana_umai ◦ GitHub: @bananaumai ◦ LinkedIn: Yuta Shimakawa
© 2023 MODE, Inc. 11 MODE is hiring
© 2023 MODE, Inc. 12