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
Microservices for toB
Search
chibicco
September 30, 2021
Programming
0
240
Microservices for toB
chibicco
September 30, 2021
Tweet
Share
More Decks by chibicco
See All by chibicco
ソフトウェアアーキテクトのススメ
chibicco
0
500
Other Decks in Programming
See All in Programming
Compiling Python to WebAssembly with py2wasm
syrusakbary
0
140
GitHub Copilot Tips and Tricks
yuichielectric
26
7.4k
OpenTelemetry のサービスという概念について
azukiazusa1
1
400
Introduction for Open Source Swift Workshop
giginet
PRO
0
180
孤独のCTOグルメという やや奇抜な企画をやった目的と効果
shoheimitani
3
1k
プロンプトエンジニアリング入門
tomokusaba
2
980
The Future of C++ Interoperability: Insights from Porting a Game to Swift
teamhimeh
0
270
Prepare for Jakarta EE 11 - Performance and Developer Productivity
ivargrimstad
0
500
「コンパイル時のユニットテスト」導入するとユニットテストを 書かなくてよくなるのか?
tomohisa
9
2.2k
WebComponentsで フレームワークを1ページに共存させる
webuilder240
0
150
ISUCONってなんだか難しそう……!!でも、初めてのISUCONにPHPで挑戦してきました!
kotomin_m
1
300
Kotlinを用いたDSL的な設計手法と使用上の注意
kohii00
3
530
Featured
See All Featured
Navigating Team Friction
lara
177
13k
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
1
3.3k
Keith and Marios Guide to Fast Websites
keithpitt
407
22k
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
219
21k
Gamification - CAS2011
davidbonilla
76
4.5k
Product Roadmaps are Hard
iamctodd
43
9.6k
The Cost Of JavaScript in 2023
addyosmani
13
3.7k
Optimising Largest Contentful Paint
csswizardry
7
2.3k
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
67
38k
Designing Dashboards & Data Visualisations in Web Apps
destraynor
225
51k
Rails Girls Zürich Keynote
gr2m
91
13k
For a Future-Friendly Web
brad_frost
170
8.9k
Transcript
Microservices for toB 2021年9月30日
自己紹介 2 2019年1月:マネーフォワード入社。 前職までは、ソーシャルゲーム業界(BtoC領域)のサーバサイドエンジニアと して、新規アプリ立ち上げ〜運用まで一通りのサーバサイド業務に携わり、 周年イベントと大量のデータに奮闘していた。
現職では、経理財務プロダクトのサーバエンジニアとして運用・開発に携わ り、2021年より同プロダクトのアーキテクチャ改善を推し進めている。 鈴木 栄次 経理財務プロダクト本部 アーキテクチャ部 Architectグループ (すずき えいじ)
3 社 名 株式会社マネーフォワード 設 立 2012年5月 上場市場 東京証券取引所市場第一部
【証券コード:3994】 本社所在地 〒108-0023 東京都港区芝浦3-1-21 msb Tamachi 田町ステーションタワーS 21F 3 お金を前へ。人生をもっと前へ。 MISSION 会社概要
02 目 次 4 はじめに マイクロサービス化 DDD ドメイン知識
おわりに 成長し続けるサービス ソーシャルゲームと会計の違い
はじめに
プロダクト 6
プロダクト(私の担当領域) 7
担当するサービスの特性 8 • 性質的にはBtoBtoCが近い • toC/toBともにターゲット
ソーシャルゲームと会計の違い
10 データ量や高アクセスの考慮
11 サービス間連携
12 法律の存在
それ、toBだからかも? 13
成長し続けるサービス
15 開発速度の低下
サービス間連携 16 外部サービス
17 データの肥大化
18 分割で複雑さに立ち向かえ
マイクロサービス化
前提条件 20 Rapid provisioning 数時間で新しいサーバを立ち上げることができる状態にする。 最初から全て自動化する必要はないが、マイクロサービスを本格化させ るためにはそれも必要になってくる。 Basic Monitoring 技術的な問題(エラーやサービスの状態)についてはもちろん、
発注数の減少などビジネス的な定常性についてもモニタリングする価値 がある。問題が発生した場合にはすぐにロールバックできる必要があ る。 Rapid application deployment 環境にかかわらず、迅速にデプロイできる必要がある。 初期段階での手作業は問題ないが、いずれ完全に自動化することにな る。
21
22 関心毎を分離する
23 機能を小分けにして、 APIでデータをやり取りする
24 例えば...
クラウド 会計 25 仕訳 勘定科目 レポート 明細
None
None
None
29 素直に分解すると
クラウド 会計 30 仕訳 勘定科目 レポート 明細
クラウド 会計 31 仕訳 勘定科目 レポート 明細
DDD ドメイン知識
ドメイン知識とは 33 取り組んでいる分野に対する知識
34 ドメイン知識を元に認識を共通化
35 既に手作業で進めている事をデジタ ルにしている
クラウド 会計 36 仕訳 勘定科目 レポート 明細
サービスA クラウド 会計 37 仕訳 勘定科目 レポート 明細API
サービスB サービスA クラウド 会計 38 仕訳 勘定科目’ レポート 明細’ 勘定科目
明細API
プロダクト(私の担当領域) 39
サービスB サービスA クラウド 会計 40 仕訳 レポート 明細’ マスター データ
明細API 経費 請求書
41 まだまだ長い道の途中
おわりに
まとめ 43 • 目的があり、常にそれを考える • マイクロサービスは手段 • ドメイン知識はマイクロサービスに関わらず重要である
We’re hiring!! 44
45 ご清聴ありがとうございました