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
Yusuke Kishino
June 18, 2024
Programming
1
280
リアーキテクチャのアンチパターンとその対策 〜ラクスルの場合〜
Yusuke Kishino
June 18, 2024
Tweet
Share
More Decks by Yusuke Kishino
See All by Yusuke Kishino
RAKSULに見るアーキテクチャの変遷 - 複数サービス展開への道
yusukekishino
2
470
ROSCAFE TECH NIGHT #2 〜今、CTO / VPoEに求められる事とは?〜
yusukekishino
0
300
Other Decks in Programming
See All in Programming
他言語経験者が Golangci-lint を最初のコーディングメンターにした話 / How Golangci-lint Became My First Coding Mentor: A Story from a Polyglot Programmer
uma31
0
480
AI Agent 時代的開發者生存指南
eddie
4
2.2k
AI 駆動開発におけるコミュニティと AWS CDK の価値
konokenj
5
300
20251016_Rails News ~Rails 8.1の足音を聴く~
morimorihoge
3
890
Introducing RemoteCompose: break your UI out of the app sandbox.
camaelon
2
160
NixOS + Kubernetesで構築する自宅サーバーのすべて
ichi_h3
0
1.3k
Module Proxyのマニアックな話 / Niche Topics in Module Proxy
kuro_kurorrr
0
190
TransformerからMCPまで(現代AIを理解するための羅針盤)
mickey_kubo
7
5.8k
One Enishi After Another
snoozer05
PRO
0
170
ボトムアップの生成AI活用を推進する社内AIエージェント開発
aku11i
0
1.2k
When Dependencies Fail: Building Antifragile Applications in a Fragile World
selcukusta
0
120
iOSでSVG画像を扱う
kishikawakatsumi
0
180
Featured
See All Featured
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
54k
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
48
9.7k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
132
19k
Done Done
chrislema
185
16k
Practical Tips for Bootstrapping Information Extraction Pipelines
honnibal
PRO
23
1.5k
StorybookのUI Testing Handbookを読んだ
zakiyama
31
6.3k
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
32
1.7k
Imperfection Machines: The Place of Print at Facebook
scottboms
269
13k
Six Lessons from altMBA
skipperchong
29
4k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
9
1k
Keith and Marios Guide to Fast Websites
keithpitt
411
23k
Facilitating Awesome Meetings
lara
57
6.6k
Transcript
リアーキテクチャのアンチパターンとその対策 〜ラクスルの場合〜 ラクスル株式会社 ラクスル事業本部 CTO 岸野 友輔 2024.06.18 Ver.1.0.0
© 2021 RAKSUL, inc. All rights reserved. 社外秘 Confidential これまでの経歴
• 2017年:東京工業大学卒 • 2017-2020年: ラクスル サーバーサイドエンジニア • 2021-2023年: ダンボールワン サーバーサイドエンジニア/CTO • 2023年-現在: ラクスル事業本部CTO ◦ 共通基盤プロダクト構築の推進など これまでやってきた技術 • Ruby/Go/PHP 岸野 友輔(Kishino Yusuke) サーバーサイドエンジニア 趣味:ゲーム, 自転車, 料理
© RAKSUL, inc. All rights reserved. 今日のテーマ 3 本日のイベントの前身となる 5/22に行われたイベントで語りきれなかったことを中心に、ラクスル
のアーキテクチャの変遷と踏んでしまったアンチパターンについてお話しします 前回のイベントレポートはこちら!
© RAKSUL, inc. All rights reserved. ラクスルってどんなサービス? 4
© RAKSUL, inc. All rights reserved. 5 ラクスル事業について 印刷EC事業に始まり『広告(集客支援)事業』『ノベルティ・グッズ事業』 『ダンボール・梱包材事業』『アパレル・ユニフォーム事業』などを展開している事業体
ダンボール・梱包資材の 受発注プラットフォーム ノベルティ・グッズの 受発注プラットフォーム +非公開の事業群 アパレル・ユニフォームの 受発注プラットフォーム
© RAKSUL, inc. All rights reserved. ラクスル事業のサービス・アーキテクチャの変遷 6
© RAKSUL, inc. All rights reserved. 印刷のラクスルの始まり - 1サービス・ 1プロダクト
サービス 2013年 印刷ECである「ラクスル 」リリース 7 アーキテクチャ PHPで作られたモノリシックなシステム DB
© RAKSUL, inc. All rights reserved. 複数サービスの始まり - 複数サービス・ 1プロダクト
サービス 2015年 印刷ECサイトのラクスルを拡張 する形で集 客支援サービス (新聞折込やポスティング )開始 8 アーキテクチャ モノリスを拡張 しながらサービスを拡大 設計が苦しく なり始めマイクロサービス化を検討 DB New
© RAKSUL, inc. All rights reserved. マイクロサービス化の始まり - 複数サービス・ 1プロダクト
サービス 2015年 印刷ECサイトのラクスルを拡張 する形で集 客支援サービス (新聞折込やポスティング )開始 9 アーキテクチャ 一部マイクロサービス化 を開始(DBを共有するアン チパターンを踏む) DB New
© RAKSUL, inc. All rights reserved. マルチプロダクトの始まり - 複数サービス・複数プロダクト サービス
紙への印刷から大きく異なる「 ノベルティ 」や「アパレ ル」のECを展開 10 アーキテクチャ 印刷ECが拡張の限界 を迎えたため新規でのサービス を別プロダクト として構築していく方針へ 共通基盤 として決済基盤 が構築される 共通の認証機能 は印刷ECにくっついたまま 認証 決済基盤 認証 New New New
© RAKSUL, inc. All rights reserved. M&Aの発生 - 複数サービス・複数プロダクト・ M&A
サービス 梱包材ECの「ダンボールワン 」と ハンコECの「ハンコヤドットコム 」がM&Aによりグ ループイン シナジーの創出 が求められる アーキテクチャ M&Aを想定していなかった アーキテクチャに対してシナ ジー創出の戦略の元に ID連携や決済の連携 が求めら れる このままでは耐えられない ... 11 認証 決済基盤 認証 New New IDはどうする? 決済は繋げられる?
© RAKSUL, inc. All rights reserved. ラクスル事業のサービス・アンチパターン 12
© RAKSUL, inc. All rights reserved. マイクロサービス化の始まり - 複数サービス・ 1プロダクト
サービス 2015年 印刷ECサイトのラクスルを拡張 する形で集 客支援サービス (新聞折込やポスティング )開始 13 アーキテクチャ 一部マイクロサービス化 を開始(DBを共有するアン チパターンを踏む) DB New
© RAKSUL, inc. All rights reserved. もう少し詳細に 14 EC DB
EC機能本体 旧 新 印刷発注 API 印刷原価 計算 原価 DB 切り出し 切り出し
© RAKSUL, inc. All rights reserved. 抱えている課題 15 EC DB
EC機能本体 旧 新 印刷発注 API 印刷原価 計算 原価 DB DBを共有 同一テーブルを複数 のアプリケーションか ら参照 実際に切り出せたのは 一部商材のみ
© RAKSUL, inc. All rights reserved. モノリスからマイクロサービス化へのパターン 16 DB アプリケーションを先に分ける
モノリス 新 DB DBを先に分ける モノリス 新DB DB 同時に分ける モノリス 新DB 新 メリット ・短期的にはマイクロサービス化の恩恵を 受けやすい デメリット ・DBを共有したままにすると徐々に辛くなる ・テーブルスキーマの変更に複数のアプリ ケーションが追従しなくてはならない メリット ・データを軸に切り分け方を探索し易い ・比較的切り戻しし易い デメリット ・短期的なメリットは薄い メリット ・切り分け方が明確であれば一度に理想状 態に移行できる デメリット ・難易度が高い ・一発できれいに切り分けられない ・設計・開発に時間がかかるので最初に恩恵 を受けられるまでの時間軸が長い
© RAKSUL, inc. All rights reserved. 課題にどう向き合っているか 17 EC DB
EC機能本体 旧 新 印刷発注 API 印刷原価 計算 原価 DB 印刷発注基盤 DB 印刷発注 基盤 廃止する方針 一定辛みを伴うが再度責務を切り直し印刷のラクスルだけでなく他サービスからも利用できるような形でリアーキテクチャ 以前のマイクロサービス化で得られた知見を元にあるべき姿で作り直し中 → もともとのマイクロサービス化は無駄では無かった 移行のやりきり
© RAKSUL, inc. All rights reserved. まとめ・学び • 当時の判断としては必ずしも間違っているわけではなかった ◦
拡張の難しいレガシーコードに変更を加えるより、コードを切り出したほうが短期的にはリリー スが速かった ◦ ベンチャーにおいて速さは重要 • アンチパターンとしては共有DBをそのままにし続けてしまったこと ◦ 2重メンテ、3重メンテが頻発する結果に • マイクロサービス化を進めるのであればゴール設定は重要 ◦ 中途半端になってしまうと事態は悪化する ◦ あるべき姿を描き、あるべきに向けたステップを明確化してからスタートすべし 18
© RAKSUL, inc. All rights reserved. WE ARE HIRING!