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
巨大なモノリシック Rails アプリケーションの マイクロサービス化戦略 / 2019 mi...
Search
Kazuhito Hokamura
March 23, 2019
Technology
4.1k
3
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
巨大なモノリシック Rails アプリケーションの マイクロサービス化戦略 / 2019 microservices in cookpad
Kazuhito Hokamura
March 23, 2019
More Decks by Kazuhito Hokamura
See All by Kazuhito Hokamura
TypeScriptとGraphQLで実現する 型安全なAPI実装 / TSKaigi 2024
hokaccha
5
5.1k
Kotlin製のGraphQLサーバーをNode.jsでモジュラモノリス化している話
hokaccha
0
3.8k
GraphQLの負債と向き合うためにやっていること
hokaccha
2
1.6k
ユビーのアーキテクチャに対する取り組み
hokaccha
1
490
RailsエンジニアのためのNext.js入門
hokaccha
7
22k
Cookpad Summer Internship 2021 Web Frontend
hokaccha
0
7.4k
巨大なRailsアプリケーションを「普通」にするための取り組み
hokaccha
1
1.1k
Web Frontend Improvement in Cookpad
hokaccha
1
1.2k
cookpad summer internship 2018 - Git
hokaccha
1
9.8k
Other Decks in Technology
See All in Technology
LayerXにおけるセキュリティ管理の現在地と次の一手
tosho
0
240
あなたの知らないPDFのアクセシビリティ
lycorptech_jp
PRO
0
210
データサイエンスを価値につなげるプロジェクト設計 〜 DS一年目が現場で得た気づき 〜
ysd113
1
270
【NRUG vol.18】KubernetesにおけるNew Relicデータ取得量削減の考え方
nrug_member
0
160
Chainlitで作るお手軽チャットUI
ynt0485
0
270
SteampipeとExcel Power QueryでAWS構成定義書の作成を自動化する
jhashimoto
0
120
脱SaaS!FDEを支えるプロビジョニングと分離設計
knih
0
160
やさしいA2A入門
minorun365
PRO
12
1.9k
いまさら聞けない「仕様駆動開発入門」 〜AI活用時代の開発プロセスを考える〜
findy_eventslides
2
160
AIネイティブな開発のサプライチェーンリスク対策 〜激動の開発現場でリスクに立ち向かう〜【ZennFes】
cscengineer
PRO
2
140
2026年6月23日 Syncable Tech + Start Python Club にて
hamukazu
0
130
入門!AWS Blocks
ysuzuki
1
150
Featured
See All Featured
[SF Ruby Conf 2025] Rails X
palkan
2
1.1k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.8k
Applied NLP in the Age of Generative AI
inesmontani
PRO
4
2.3k
Prompt Engineering for Job Search
mfonobong
0
350
Dealing with People You Can't Stand - Big Design 2015
cassininazir
367
27k
The Art of Programming - Codeland 2020
erikaheidi
57
14k
How Fast Is Fast Enough? [PerfNow 2025]
tammyeverts
3
610
Amusing Abliteration
ianozsvald
1
210
Agile Actions for Facilitating Distributed Teams - ADO2019
mkilby
0
210
技術選定の審美眼(2025年版) / Understanding the Spiral of Technologies 2025 edition
twada
PRO
118
120k
It's Worth the Effort
3n
188
29k
What Being in a Rock Band Can Teach Us About Real World SEO
427marketing
0
250
Transcript
巨大なモノリシック Rails アプリケーションの マイクロサービス化戦略 Rails Developers Meetup 2019 @hokaccha
•Kazuhito Hokamura • @hokaccha • Cookpad Inc. • Lead of
service infra team • Nodebrew, Adventar
None
αʔϏε։͔࢝ΒҎ্ 3BJMTԽͯ͠Ҏ্
$ cloc . -------------------------------------------------------------------------------- Language files blank comment code --------------------------------------------------------------------------------
Ruby 7499 96381 16074 507178 Haml 4494 14510 592 129029 Sass 1010 19237 543 120166 Markdown 223 6888 0 65316 XML 88 25 30 59334 JavaScript 269 8097 10565 51189 YAML 75 878 668 36879 ERB 911 3927 83 25839 CoffeeScript 409 2860 405 16211 CSS 10 175 64 5992 ... -------------------------------------------------------------------------------- SUM: 15200 154731 31233 1025936 --------------------------------------------------------------------------------
0EBJCB1SPKFDU
取り組み •コード削除 •コンテナ化 •システム分離
None
コンテナ化
None
DPPLQBE@BMM DPPLQBE 8FC3&45"1* QBQBʢཧը໘ʣ LVSPLPʢόονδϣϒʣ NPCJMFʢΨϥέʔʣ
DPPLQBE 8FC3&45"1* QBQBʢཧը໘ʣ LVSPLPʢόονδϣϒʣ NPCJMFʢΨϥέʔʣ DPPLQBE@BMM DPPLQBE 8FC QBQBʢཧը໘ʣ LVSPLPʢόονδϣϒʣ
QBOUSZ 3&45"1* NPCJMFʢΨϥέʔʣ DPPLQBE@BMM
DPPLQBE 8FC3&45"1* QBQBʢཧը໘ʣ LVSPLPʢόονδϣϒʣ NPCJMFʢΨϥέʔʣ DPPLQBE@BMM DPPLQBE 8FC QBQBʢཧը໘ʣ LVSPLPʢόονδϣϒʣ
QBOUSZ 3&45"1* NPCJMFʢΨϥέʔʣ DPPLQBE@BMM
システム分離
None
データの切れ目で分離する
•30以上の異なる DB への接続 •10以上の異なる Redis への接続 •他にも Solr, GDBM など
システム分離ケーススタディ
1. 検索システム
検索システム •クックパッドの検索を支えるシステム •Solr をバックエンドにしている •すごく複雑なドメインロジックの塊
None
2. 料理きろく
料理きろく •料理の写真だけを自動で判別して記録 •クックパッドアプリの1機能 •DB は別だがコードは cookpad_all に 含まれていた
移行前 NBJO DPPLJOH@MPH 1BOUSZ
移行中 NBJO DPPLJOH@MPH 1BOUSZ DPPLJOHMPH
移行後 NBJO DPPLJOH@MPH 1BOUSZ DPPLJOHMPH
3. モバれぴ
モバれぴ •ガラケー向けのサイト •機能追加やメンテナンスはほぼしていない •アクティブなユーザは健在 •cookpad_all から切り出してフリーズ させることを決断
最新の技術で動くガラケーサイトに... •Ruby 2.6 •Rails 5.2 •Docker / ECS •Service Mesh
•gRPC
移行手順 /FX 0ME Ұ୴ͯ͢ͷϦΫΤετΛ৽αʔόʔʹྲྀ͢
移行手順 /FX 0ME ࣮͍ͯ͠ΔΤϯυϙΠϯτ ͦͷ··ॲཧͯ͠ϨεϙϯεΛฦ͢
移行手順 /FX 0ME ະ࣮ͷΤϯυϙΠϯτΛฦ͢
移行手順 /FX 0ME /HJOY͕Λड͚औͬͨΒ چαʔόʔʹϑΥʔϧόοΫ ະ࣮ͷΤϯυϙΠϯτΛฦ͢
͜͜ΒΜͰΓସ͑
Webフロントエンド
$ cloc . -------------------------------------------------------------------------------- Language files blank comment code --------------------------------------------------------------------------------
Ruby 7499 96381 16074 507178 Haml 4494 14510 592 129029 Sass 1010 19237 543 120166 Markdown 223 6888 0 65316 XML 88 25 30 59334 JavaScript 269 8097 10565 51189 YAML 75 878 668 36879 ERB 911 3927 83 25839 CoffeeScript 409 2860 405 16211 CSS 10 175 64 5992 ... -------------------------------------------------------------------------------- SUM: 15200 154731 31233 1025936 --------------------------------------------------------------------------------
$ cloc . -------------------------------------------------------------------------------- Language files blank comment code --------------------------------------------------------------------------------
Ruby 7499 96381 16074 507178 Haml 4494 14510 592 129029 Sass 1010 19237 543 120166 Markdown 223 6888 0 65316 XML 88 25 30 59334 JavaScript 269 8097 10565 51189 YAML 75 878 668 36879 ERB 911 3927 83 25839 CoffeeScript 409 2860 405 16211 CSS 10 175 64 5992 ... -------------------------------------------------------------------------------- SUM: 15200 154731 31233 1025936 --------------------------------------------------------------------------------
レガシーな開発環境 •CoffeeScript •Zepto •Asset Pipeline •vendor/assets によるライブラリ管理
$ cloc . -------------------------------------------------------------------------------- Language files blank comment code --------------------------------------------------------------------------------
Ruby 7499 96381 16074 507178 Haml 4494 14510 592 129029 Sass 1010 19237 543 120166 Markdown 223 6888 0 65316 XML 88 25 30 59334 JavaScript 269 8097 10565 51189 YAML 75 878 668 36879 ERB 911 3927 83 25839 CoffeeScript 409 2860 405 16211 CSS 10 175 64 5992 ... -------------------------------------------------------------------------------- SUM: 15200 154731 31233 1025936 --------------------------------------------------------------------------------
$ cloc . -------------------------------------------------------------------------------- Language files blank comment code --------------------------------------------------------------------------------
Ruby 7499 96381 16074 507178 Haml 4494 14510 592 129029 Sass 1010 19237 543 120166 Markdown 223 6888 0 65316 XML 88 25 30 59334 JavaScript 269 8097 10565 51189 YAML 75 878 668 36879 ERB 911 3927 83 25839 CoffeeScript 409 2860 405 16211 CSS 10 175 64 5992 ... -------------------------------------------------------------------------------- SUM: 15200 154731 31233 1025936 --------------------------------------------------------------------------------
None
None
None
None
• クックパッドでは1ページに複数の機能が混在 するようなケースは少ない • コントローラー単位ぐらいで分けるのがいいのでは
"HHSJHBUJPO-BZFS FH(SBQI2- BFFで分割するパターン ,JUDIFO #BDLFOE #BDLFOE 'SPOUFOE 4FBSDI #BDLFOE 6TFS
#BDLFOE 3FDJQF #BDLFOE ,JUDIFO 'SPOUFOE 4FBSDI 'SPOUFOE 3FDJQF 'SPOUFOE
課題 •ページ間でのUIの統一 •共通コンポーネントの管理 •ページをまたいだ施策はどうする •セッション、Cookie、ログ、etc...
まとめ
マイクロサービスは難しい
しかしサービスの成長のためには目を背けることが できないのでやっていってます
ありがとうございました