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
プロダクトを成長させるために、エンジニアリングするべきこと/Product tidying u...
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Daisuke Sato
November 22, 2019
Technology
190
1
Share
プロダクトを成長させるために、エンジニアリングするべきこと/Product tidying up at engineering
#レガシー感謝の日
https://askul.connpass.com/event/152688/
Daisuke Sato
November 22, 2019
More Decks by Daisuke Sato
See All by Daisuke Sato
人と組織に偏重したEMへのアンチテーゼ──なぜ、EMに設計力が必要なのか/An antithesis to the overemphasis of people and organizations in EM
dskst
8
1.2k
エンジニアのための事業貢献入門/A business introduction for engineers
dskst
93
31k
Management Workflow
dskst
2
590
スタートアップのマネージャーに役立つ視座/A useful perspective for startup managers
dskst
6
2.1k
「時」と「場」を捉える、プロダクトづくりのためのリーダーシップ/Leadership for product creation that captures time and place
dskst
3
670
事業紹介/Joystruct
dskst
0
4.2k
キャリア理論をもとに考えるエンジニアのキャリア/Engineer's careers based on career theory
dskst
10
5.4k
ソフトウェア開発とマネジメント/Software Development and Management
dskst
6
7.3k
エンジニアのためのマネジメント入門/Introduction to Management for Software Engineers
dskst
11
9.8k
Other Decks in Technology
See All in Technology
TypeScriptとAngular Signal で実現する保守性の高いアプリケーション設計 - 3層アーキテクチャによる責務分離の実践(たつかわ) https://2026.tskaigi.org/talks/10
nealle
1
350
AI時代の私の技術インプットとアウトプット術
tonkotsuboy_com
12
6k
TSKaigi 2026 - Auth.jsからBetter Authへの 移行に見る「型とランタイム」の 設計思想の変化
teamlab
PRO
1
260
大学生が本気でDatabricksを活用してDiscordサークルをデータ駆動させてみた
phantomjuju
0
120
CloudFront VPCオリジンとVPC Latticeサービスの内部ALBをマルチアカウントで一元利用しよう
duelist2020jp
5
240
checker.tsにチキンレースを仕掛けてみた:型エラー(TS2589)が発生する境界線を求めて
hal_spidernight
1
200
TypeScript の型で副作用の実行順序を制御する
yanaemon
2
210
AIコーディングエージェントの活用で、コードは静かに肥大化した
yosukeshinoda
1
370
ラズパイ & Picoで入門:Zephyr(RTOS)の環境構築からビルドまでの紹介
iotengineer22
0
240
oracle-to-databricks-migration-with-llm-and-dbt
casek
0
160
組織の中で自分を経営する技術
shoota
0
150
A Harness for Behaviour: how to get AI to generate code that does what we intend, or "TDD in the age of AI"
xpmatteo
0
430
Featured
See All Featured
BBQ
matthewcrist
89
10k
Utilizing Notion as your number one productivity tool
mfonobong
4
310
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
35
2.4k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
234
17k
Prompt Engineering for Job Search
mfonobong
0
320
Documentation Writing (for coders)
carmenintech
77
5.3k
Practical Tips for Bootstrapping Information Extraction Pipelines
honnibal
25
1.9k
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
37
6.4k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
17k
It's Worth the Effort
3n
188
29k
How to optimise 3,500 product descriptions for ecommerce in one day using ChatGPT
katarinadahlin
PRO
1
3.6k
Transcript
プロダクト成長させるために、 エンジニアリングするべきこと 2019.11.22 レガシー感謝の日 @dskst9
さとうだいすけ @dskst9 アスクル株式会社 エンジニアリングマネージャー エンジニアリングマネージャーってクールだよね というのを世の中に広めたい
LOHACO 「LOHACO」の由来は、Lots of Happy Communities “くらしをかるくする”をコンセプトに、暮らしを潤すこだわりの商品を、いつでもリーズナブ ルかつスピーディーにお届けする日用品ショッピングサイト
One year ago...
One year ago...
One year ago...
One year ago...
One year ago...
One year ago...
レガシーと戦った1年間のお話 • 注文コアシステムのリニューアル • レガシーをモダナイズ • プロダクトとの向き合い
私たちのレガシー LOHACOは2012年にサービス開始 • 巨大なモノリシックシステム • 溜まりに溜まった技術的負債 • なぜ動いているかわからないスパゲティ コード •
誰もしらない機能
私たちのレガシー:古え WEB App DB
私たちのレガシー:ぼちぼち古い Web App DB
私たちのレガシー:ぼちぼち古い Web App DB コア機能が ここにあるまま…!
変化に適応できない
生き残る種とは、 最も強いものではない。 最も知的なものでもない。 それは、変化に最もよく適応し たものである。 チャールズ・ダーウィン
変化に適応できない • スケールできない • 処理が遅い • 触ると事故る
変化に適応できない • スケールできない • 処理が遅い • 触ると事故る 彼みたいに、 変化を望めばいつか 対応できるのか?
彼→
キリンの首は、 最初から長かった。
アーキテクチャという骨 アーキテクチャという骨は、 望んでも伸びない太くならない。
変化に適応できるシステムを作り直す • 変化に強いソフトウェア 変更を迅速で安全に行うことができる • 変化に強いシステム システムの他の部分を変更する必要なし に、あるサービスを変更できる
変化に適応できるシステムとは 高凝集 && 低結合
高凝集 && 低結合 == 変更容易性 • レイヤード、オニオン、ヘキサゴナル、ク リーンアーキテクチャ • マイクロサービスアーキテクチャ、モジュラ
モノリス • DDD、オブジェクト指向 など、いろいろとあるが
高凝集 && 低結合 != 変更容易性
高凝集 && 低結合 != 変更容易性 複雑すぎると アンコントラーラブル
理想と現実の境界線 • 時間との戦い • 経験との戦い • 不確実性との戦い
戦いは、 正を以って合いし、 奇を以って勝つ。 孫氏
(それなりに…) 高凝集 && 低結合 == 変更容易性
(それなりに…) 高凝集 && 低結合 == 変更容易性 • クリーンなアーキテクチャ • マイクロサービス移行段階的
アーキテクチャ • DDDをまずは始める • ちゃんとしたテスト書く
ソフトウェアスタック Web App DB
骨はできた☠
次は肉
プロダクトのデトックス • 贅肉が溜まる • 老廃物が溜まる • 毒素が溜まる
何をしないか決めるのは、 何をするのかを決めるのと同 じくらい大事だ。 スティーブ・ジョブズ
65
統廃合した機能数
機能のリファクタリング • 明確なファクトを集める • 信じれる数字で会話する • 負債と呼んだものは資産かもしれない
機能のリファクタリング • 明確なファクトを集める • 信じれる数字で会話する • 負債と呼んだものは資産かもしれない 最終手段 試しに削除してみる
やりすぎると失敗する • いいじゃん、やってみよ • ってやると、意外に利用されていることもある • やりすぎ注意、明確なファクトを集めよ
作らないものづくり 成長し続けるとは 何かを作り続けることではない。
作らないものづくり 成長し続けるとは 何かを作り続けることではない。 何かを無くすことも重要である。
プロダクト成長段階 1. Early Phase: 初期段階 2. Growth Phase: 成長段階 3.
Hyper Growth Phase: 超 成長段階 4. Mature Phase: 成熟段階
プロダクト成長段階 (こんな式で計算できる)
プロダクト成長段階 さらなる製品の成長や新たな 環境における成長は 、 再びS字カーブをなぞる。
検証は プロダクトが成長する限り 続いていく
Thanks Legacy, Goodbye Legacy.