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
ドメインを中心にしたプロダクト開発/domain-driven-product
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
hiro@miraito
September 14, 2023
Programming
1
1.3k
ドメインを中心にしたプロダクト開発/domain-driven-product
2023.9.14
asken withミライトデザインのDDDのはじめ方 DDD x RDRA x ICONIX にて
株式会社ミライトデザイン
林宏勝
hiro@miraito
September 14, 2023
Tweet
Share
More Decks by hiro@miraito
See All by hiro@miraito
沖田畷の戦い/Battle-of-Okitanawate
hirodragon112
0
310
僕がユースケース駆動開発をする理由/my-usecase-driven-development
hirodragon112
2
9.4k
ICONIXプロセスから学ぶオブジェクト指向モデリング/ICONIX for Object-Oriented
hirodragon112
4
4k
DDD時代に考えたいICONIXプロセス/ICONIX in DDD
hirodragon112
10
4.7k
概念投影によるオブジェクト指向設計の考え方とその方法/Conceptual projection design
hirodragon112
15
5.9k
意訳Domain-Driven Design
hirodragon112
4
1.5k
カンファレンス主催者から見たCfPとプロポーザル
hirodragon112
0
2.2k
DDD導入に踏み切れない方へ贈る「2層 + CQS アーキテクチャ(Flyweight DDD)」/Flyweight DDD
hirodragon112
26
8.7k
Other Decks in Programming
See All in Programming
株式会社 Sun terras カンパニーデック
sunterras
0
1.9k
Event Storming
hschwentner
3
1.3k
PostgreSQL を使った快適な go test 環境を求めて
otakakot
0
360
24時間止められないシステムを守る-医療ITにおけるランサムウェア対策の実際
koukimiura
2
180
TROCCOで実現するkintone+BigQueryによるオペレーション改善
ssxota
0
110
The Past, Present, and Future of Enterprise Java
ivargrimstad
0
300
Go Conference mini in Sendai 2026 : Goに新機能を提案し実装されるまでのフロー徹底解説
yamatoya
0
450
AIと一緒にレガシーに向き合ってみた
nyafunta9858
0
440
エージェント開発初心者の僕がエージェントを作った話と今後やりたいこと
thasu0123
0
210
Head of Engineeringが現場で回した生産性向上施策 2025→2026
gessy0129
0
200
ぼくの開発環境2026
yuzneri
1
290
15年目のiOSアプリを1から作り直す技術
teakun
0
570
Featured
See All Featured
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.3k
Applied NLP in the Age of Generative AI
inesmontani
PRO
4
2.1k
世界の人気アプリ100個を分析して見えたペイウォール設計の心得
akihiro_kokubo
PRO
67
37k
Groundhog Day: Seeking Process in Gaming for Health
codingconduct
0
110
Deep Space Network (abreviated)
tonyrice
0
79
The MySQL Ecosystem @ GitHub 2015
samlambert
251
13k
Fantastic passwords and where to find them - at NoRuKo
philnash
52
3.6k
Ten Tips & Tricks for a 🌱 transition
stuffmc
0
82
Git: the NoSQL Database
bkeepers
PRO
432
66k
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
234
17k
Heart Work Chapter 1 - Part 1
lfama
PRO
5
35k
How to build an LLM SEO readiness audit: a practical framework
nmsamuel
1
660
Transcript
ドメインを中心にした プロダクト開発 asken withミライトデザインのDDDのはじめ方 DDD x RDRA x ICONIX 2023.09.14
@林 宏勝(株式会社ミライトデザイン) 資料 https://speakerdeck.com/hirodragon112/domain-driven-product
ドメインを中心にしたプロダクト開発 2 林 宏勝(X : hiro@miraito) 株式会社ミライトデザイン CEO Object Oriented
Conference2020主催 ドメイン駆動設計入門レビュアー OOPやDDD中心に設計などに興味があります 自己紹介
ドメインを中心にしたプロダクト開発 3 「確かな設計によるよりよいシステムを」 主に上流工程・コンサルから開発・運用まで幅広く プロダクト開発のお手伝いをしています 会社紹介 株式会社ミライトデザイン
ドメインを中心にしたプロダクト開発 4 勉強会「ペチオブ」開催 https://phper-oop.connpass.com/ 設計・アジャイル・要件定義・その他諸々 プロダクト開発に関する色んな事を一緒に学ぼう という勉強会 月一第一木曜日に開催中 会社紹介
ドメインを中心にしたプロダクト開発 5 Youtube :Mirait Channel https://www.youtube.com/@miraito エンジニアリングに関する動画から関係ない 動画まで不定期更新してますので、チャンネ ル登録よろしくお願いします! 会社紹介
ドメインを中心にしたプロダクト開発 6 ドメインを中心にしたプロダクト開発とは??
ドメインを中心にしたプロダクト開発 7 その前に 一般的に理想(理論)と現実のギャップが必ずある事を理解する • 全てを作り直す事はできないケースがある • データ構造にいきなり手を入れられないケースがある • 効果測定をしたくても既存システムにその仕組みがない(入れられない)
• 等々 理論の話しではなく実務の話しなのでその辺を気にしながら話します
ドメインを中心にしたプロダクト開発 8 リニューアルの成功とは? 既存課題が解決できる事 潜在課題に対処できる事 解決?対処?
ドメインを中心にしたプロダクト開発 9 理想 定量的に成功のGoalを決めたい 現実 既存の問題等を数値化する仕組みがない(数値化するのが困難) デプロイが楽になった 修正や機能追加が容易になった ソースコードが理解しやすくなった ←定性的判断をひとまずPoCでしてもらう
ドメインを中心にしたプロダクト開発 10 進める上で意識していること 1. 教条主義にならない 2. QCDS、特にSを明確にする 3. 「何を」「なぜ」作るかを明確にする
ドメインを中心にしたプロダクト開発 11 ドメインを中心にしたプロダクト ≠教科書通りのパターンを使うこと (エリックエバンスの)ドメイン駆動設計本通りのできているかどうかを指針とし ない。 教条主義にならない
ドメインを中心にしたプロダクト開発 12 ドメインを知りそれをシステムに投影できるか ただ動くものではなく、ドメインを表現したシステム構造にできるか 現実解が常に問われる
ドメインを中心にしたプロダクト開発 13 全てを一気に作り直す事は現実的ではないが、 現実的にどの単位でわけられるかも案外複雑 Cost, Quality, は事業上必ず制約が発生するのでその上で適切な Scope, Delivery を計画する
QCDS、特にSを明確にする
ドメインを中心にしたプロダクト開発 14 世のプロダクトの大半は、何を作れば良いかわから ないまま何かを作っている プロダクト開発の恐怖の都市伝説 「何を」「なぜ」作るかを明確にする 既存システムをただトレースすると、既に不要な機能などもリニューアル 対象になってしまう。 改めてフローを整理し、どのユースケース、どの業務フローと結びついて いる機能かを明確にしていく
ドメインを中心にしたプロダクト開発 15 知る 作る 解決したい課題を知る ドメインを知る (技術的)制約をを知る 課題を解消したプロダクト ドメインを表現したプロダクト 制約を踏まえた現実解を探す
進め方
ドメインを中心にしたプロダクト開発 16 具体的に行った事 1. 業務と関連するユースケースの洗い出し 2. PoC期間に実装検証する対象のユースケース選定 3. 概念モデル作成 4.
アーキテクチャ検討 5. ユースケースから詳細設計までの流れの確認 6. Kotlinにて対象ユースケースを実装してみる 7. 上記を2~3サイクル回して、今後の開発フローとしていけるか確認
ドメインを中心にしたプロダクト開発 17 1. 業務と関連するユースケースの洗い出し 2. PoC期間に実装検証する対象のユースケース選定 Poc時に作成途中のRDRAシート RDRAで整理する 主な目的 •
コンテキストの理解 • 業務フロー整理 • 状態、バリエーションの整理 • ユースケース洗い出し • 各機能の「なぜ」を理解する
ドメインを中心にしたプロダクト開発 18 1. 業務と関連するユースケースの洗い出し 2. PoC期間に実装検証する対象のユースケース選定 RDRAで整理する Poc時に作成途中のRDRAダイアグラム
ドメインを中心にしたプロダクト開発 19 3.概念モデル作成 Poc時に作成途中の概念モデル RDRA分析と並行して概念モデルを作成する 主な目的 • 概念整理 • 用語の統一(ユビキタス言語)
• スコープの確認
ドメインを中心にしたプロダクト開発 20 4. アーキテクチャ検討 5.ユースケースから詳細設計までの流れの確認 ICONIXプロセスを使用してユースケースを詳細に落としていく 主な目的 • 分析したユースケースを実装に近づける •
自然言語とオブジェクトのマッピング • ユースケースの規模の確認 詳細はこちら DDD時代に考えたいICONIXプロセス https://speakerdeck.com/hirodragon112/iconix-in-ddd
ドメインを中心にしたプロダクト開発 21 6. Kotlinにて対象ユースケースを実装してみる 選定言語にて実際の実装を行う 主な目的 • 選定技術の実用性の確認 • 開発フローと速度の確認
• チームに浸透しそうかの確認
ドメインを中心にしたプロダクト開発 22 今後見えている課題 1. データモデルの変更が行えない為、既存のデータモデルによる制約 2. スパークタイム(昼食時)の非機能性能を確認 3. PoC以降のチームビルド
ドメインを中心にしたプロダクト開発 23 @hirodragon