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
3.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
660
Other Decks in Technology
See All in Technology
ABWG2024採択者が語るエンジニアとしての自分自身の見つけ方〜発信して、つながって、世界を広げていく〜
maimyyym
1
230
JAWS FESTA 2024「バスロケ」GPS×サーバーレスの開発と運用の舞台裏/jawsfesta2024-bus-gps-serverless
ma2shita
3
420
プルリクエストレビューを終わらせるためのチーム体制 / The Team for Completing Pull Request Reviews
nekonenene
4
2k
いまからでも遅くない!コンテナでWebアプリを動かしてみよう!コンテナハンズオン編
nomu
0
190
スクラムというコンフォートゾーンから抜け出そう!プロジェクト全体に目を向けるインセプションデッキ / Inception Deck for seeing the whole project
takaking22
3
240
開発者体験を定量的に把握する手法と活用事例
ham0215
0
150
LangGraph × Bedrock による複数の Agentic Workflow を利用した Supervisor 型のマルチエージェントの実現/langgraph-bedrock-supervisor-agent
ren8k
3
360
自分のやることに価値を見出だせるようになり、挑戦する勇気をもらったベイトソンの考え / Scrum Fest Fukuoka 2025
bonbon0605
0
170
x86-64 Assembly Essentials
latte72
4
760
開発組織を進化させる!AWSで実践するチームトポロジー
iwamot
2
610
【Forkwell】「正しく」失敗できるチームを作る──現場のリーダーのための恐怖と不安を乗り越える技術 - FL#83 / A team that can fail correctly by forkwell
i35_267
2
160
AI自体のOps 〜LLMアプリの運用、AWSサービスとOSSの使い分け〜
minorun365
PRO
9
1.3k
Featured
See All Featured
How to Ace a Technical Interview
jacobian
276
23k
Performance Is Good for Brains [We Love Speed 2024]
tammyeverts
7
660
Writing Fast Ruby
sferik
628
61k
Large-scale JavaScript Application Architecture
addyosmani
511
110k
Keith and Marios Guide to Fast Websites
keithpitt
411
22k
Become a Pro
speakerdeck
PRO
26
5.2k
How To Stay Up To Date on Web Technology
chriscoyier
790
250k
Scaling GitHub
holman
459
140k
Typedesign – Prime Four
hannesfritz
41
2.5k
Principles of Awesome APIs and How to Build Them.
keavy
126
17k
Practical Orchestrator
shlominoach
186
10k
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
28
1.9k
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