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
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
chibicco
September 30, 2021
Programming
0
270
Microservices for toB
chibicco
September 30, 2021
Tweet
Share
More Decks by chibicco
See All by chibicco
AIを活かすためのリファクタリング
chibicco
0
56
ソフトウェアアーキテクトのススメ
chibicco
0
590
Other Decks in Programming
See All in Programming
Fluid Templating in TYPO3 14
s2b
0
130
疑似コードによるプロンプト記述、どのくらい正確に実行される?
kokuyouwind
0
380
生成AIを使ったコードレビューで定性的に品質カバー
chiilog
1
270
AI & Enginnering
codelynx
0
110
プロダクトオーナーから見たSOC2 _SOC2ゆるミートアップ#2
kekekenta
0
210
副作用をどこに置くか問題:オブジェクト指向で整理する設計判断ツリー
koxya
1
610
AI前提で考えるiOSアプリのモダナイズ設計
yuukiw00w
0
230
コマンドとリード間の連携に対する脅威分析フレームワーク
pandayumi
1
450
なるべく楽してバックエンドに型をつけたい!(楽とは言ってない)
hibiki_cube
0
140
「ブロックテーマでは再現できない」は本当か?
inc2734
0
970
Rust 製のコードエディタ “Zed” を使ってみた
nearme_tech
PRO
0
170
dchart: charts from deck markup
ajstarks
3
990
Featured
See All Featured
JAMstack: Web Apps at Ludicrous Speed - All Things Open 2022
reverentgeek
1
340
Let's Do A Bunch of Simple Stuff to Make Websites Faster
chriscoyier
508
140k
Organizational Design Perspectives: An Ontology of Organizational Design Elements
kimpetersen
PRO
1
190
AI in Enterprises - Java and Open Source to the Rescue
ivargrimstad
0
1.1k
B2B Lead Gen: Tactics, Traps & Triumph
marketingsoph
0
53
Stop Working from a Prison Cell
hatefulcrawdad
273
21k
Have SEOs Ruined the Internet? - User Awareness of SEO in 2025
akashhashmi
0
270
Building Better People: How to give real-time feedback that sticks.
wjessup
370
20k
Navigating the moral maze — ethical principles for Al-driven product design
skipperchong
2
240
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
60
42k
Lightning Talk: Beautiful Slides for Beginners
inesmontani
PRO
1
440
Build your cross-platform service in a week with App Engine
jlugia
234
18k
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 ご清聴ありがとうございました