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
Real World Mercari API Architecture
Search
kazegusuri
February 01, 2018
Technology
1
6.1k
Real World Mercari API Architecture
Bonfire API #1
kazegusuri
February 01, 2018
Tweet
Share
More Decks by kazegusuri
See All by kazegusuri
go-sqlite3を使ってCloud Spannerエミュレーターを作ってみた / Cloud Spanner emulator with go-sqlite3
kazegusuri
5
6.5k
handy-spanner GCPUG
kazegusuri
4
1.8k
Open SKT: メルペイ開発の裏側 / builderscon tokyo 2019 Open SKT
kazegusuri
22
26k
Keep watching and extending features of gRPC
kazegusuri
3
2.4k
Testing with microservices in merpay
kazegusuri
10
10k
gRPC and REST with gRPC in practice
kazegusuri
19
7.7k
Fluentdで始めるPrometheus / Prometheus Tokyo Meetup #1
kazegusuri
1
1.8k
GRPCの実践と現状での利点欠点 / Go Conference 2016 Spring
kazegusuri
44
32k
OutputとBufferedOutputの間の何か
kazegusuri
2
3.2k
Other Decks in Technology
See All in Technology
Data-centric AI入門第6章:Data-centric AIの実践例
x_ttyszk
1
400
オブザーバビリティの観点でみるAWS / AWS from observability perspective
ymotongpoo
8
1.5k
RECRUIT TECH CONFERENCE 2025 プレイベント【高橋】
recruitengineers
PRO
0
160
地方拠点で エンジニアリングマネージャーってできるの? 〜地方という制約を楽しむオーナーシップとコミュニティ作り〜
1coin
1
230
バックエンドエンジニアのためのフロントエンド入門 #devsumiC
panda_program
18
7.5k
Classmethod AI Talks(CATs) #17 司会進行スライド(2025.02.19) / classmethod-ai-talks-aka-cats_moderator-slides_vol17_2025-02-19
shinyaa31
0
120
Tech Blogを書きやすい環境づくり
lycorptech_jp
PRO
1
240
個人開発から公式機能へ: PlaywrightとRailsをつなげた3年の軌跡
yusukeiwaki
11
3k
エンジニアが加速させるプロダクトディスカバリー 〜最速で価値ある機能を見つける方法〜 / product discovery accelerated by engineers
rince
4
320
スタートアップ1人目QAエンジニアが QAチームを立ち上げ、“個”からチーム、 そして“組織”に成長するまで / How to set up QA team at reiwatravel
mii3king
2
1.5k
Developer Summit 2025 [14-D-1] Yuki Hattori
yuhattor
19
6.2k
Classmethod AI Talks(CATs) #16 司会進行スライド(2025.02.12) / classmethod-ai-talks-aka-cats_moderator-slides_vol16_2025-02-12
shinyaa31
0
110
Featured
See All Featured
Large-scale JavaScript Application Architecture
addyosmani
511
110k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
666
120k
What's in a price? How to price your products and services
michaelherold
244
12k
What’s in a name? Adding method to the madness
productmarketing
PRO
22
3.3k
Building an army of robots
kneath
303
45k
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
10
1.3k
VelocityConf: Rendering Performance Case Studies
addyosmani
328
24k
Faster Mobile Websites
deanohume
306
31k
Performance Is Good for Brains [We Love Speed 2024]
tammyeverts
7
630
GraphQLの誤解/rethinking-graphql
sonatard
68
10k
Intergalactic Javascript Robots from Outer Space
tanoku
270
27k
Measuring & Analyzing Core Web Vitals
bluesmoon
6
240
Transcript
Real World Mercari API Architecture Bonfire API#1 Masahiro Sano (@kazegusuri)
自己紹介 • 佐野 正浩(@kazegusuri) • Mercari, Inc → Souzoh, Inc
→ merpay, Inc • Principal Software Engineer • サーバーサイドエンジニア • Goで決済システム全般を開発中 2
3
昨年末のMercari Advent Calendar 2017の 記事中にあった 「ソースコードのフォーク」 についてお話します 4
アーキテクチャ(~2016/12) 5 Monolithic API Monolithic API UK JP US Mercari
Client Mercari Client Atte API Atte Client 1 ソースコード 1 ソースコード
クライアントフォーク(2016/12) • アプリのソースコードをJP/US/UKでフォーク • リージョン固有の実装が複雑化 • テスト不足・QAの過負荷 • UKスタート •
US First 6
USアプリ刷新(2016/12) • フルスクラッチで開発 • Protobuf導入 • Microservice化に向けてAPI Gateway導入 • 株式会社メルカリの導入事例:Kubernetes
を駆使したマイクロサービス化 でグローバルサービスの開発効率を劇的に向上 • https://goo.gl/xcP4bb 7
アーキテクチャ(2016/12) 8 Monolithic API Monolithic API Monolithic API UK JP
US Mercari Client Mercari Client Mercari Client New Mercari Client API Gateway Atte API Atte Client 1 ソースコード
続々リリース (2017/3-5) • 2017/3 UK アプリリリース • 2017/4 US 新アプリ一本化
• Microserviceの本格導入 • 2017/5 JP メルカリカウルリリース 9
アーキテクチャ(2017/5) 10 Monolithic API Monolithic API Monolithic API UK JP
US Mercari Client Mercari Client New Mercari Client API Gateway Atte API Atte Client 1 ソースコード Kauru API Kauru Client Microservice
APIフォークの検討 • 増えてくるJPのアプリ • 構成の異なるUS/UK • メルペイに向けてのアーキテクチャ変更 • 2017/10 APIフォーク
11
アーキテクチャ(2017/10~) 12 Monolith ic API Monolithic API Monolithic API UK
JP US Mercari Client Mercari Client New Mercari Client API Gateway Atte API Kauru API MS MS MS MS MS Maisonz API MS MS MS Souzoh merpay MS MS MS
APIフォークの理由 • APIのコード的な側面 • 組織的な側面 • Microservice化へのアプローチの違い 13
APIのコード的な側面 • リージョン毎にやっていることが違いすぎる • API側で違いを吸収する必要がなくなってきた • リージョン毎に独立したエンドポイント • 修正したときに全アプリでQAするのが大変 14
組織的な側面 • 日本からUS開発の割合の変化 • 新アプリ化の時期で50:50 • US開発の現地化 • お互いが独立して異なる目的で同じソースを触る 15
Microservice化へのアプローチの違い • JPでは既存機能の共通化、プラットフォーム化が重要 • 既存機能のMicroservice化 • USでは新規機能をどんどん試していく • 新規機能をMicroservice化 •
既存機能はあまり変更しない 16
APIフォーク後 • フォークしたことでリージョン間の問題は解決 • ついでにソースコードは驚く程わかりやすく… • JPでの開発が進んだことで同じ問題がJP内でも • ソウゾウのプロダクト •
Nowやメルカリチャンネルなどの新領域 • メルペイ 17
未来に向けて • JPでもAPI Gatewayの導入(予定) • Microservice化の推進 • 異なるチームで同一システムを開発するのは難しい(個 人的感想) •
Microserviceでチームで閉じた開発体制 • システムの複雑化→運用の複雑化 • Microservice基盤の整理 • Kubernetes • CI/CD • Metrics/Tracing/Monitoring 18