$30 off During Our Annual Pro Sale. View Details »
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
DDDモデリング勉強会 #6
Search
株式会社Jurabi
October 01, 2024
Programming
0
36
DDDモデリング勉強会 #6
DDDモデリング勉強会#6 の発表資料
コンテキストマップの説明です。
株式会社Jurabi
October 01, 2024
Tweet
Share
More Decks by 株式会社Jurabi
See All by 株式会社Jurabi
DDDモデリング勉強会 #7
jurabi
0
15
DDDモデリング勉強会 #9
jurabi
0
29
Deep Learning勉強会 逆伝播の仕組み
jurabi
0
30
RDBの世界をぬりかえていくモデルグラフDB〜truncus graphによるモデルファースト開発〜
jurabi
0
370
Other Decks in Programming
See All in Programming
関数の挙動書き換える
takatofukui
4
770
CSC305 Lecture 15
javiergs
PRO
0
250
AIと協働し、イベントソーシングとアクターモデルで作る後悔しないアーキテクチャ Regret-Free Architecture with AI, Event Sourcing, and Actors
tomohisa
5
18k
Querying Design System デザインシステムの意思決定を支える構造検索
ikumatadokoro
1
1.2k
MAP, Jigsaw, Code Golf 振り返り会 by 関東Kaggler会|Jigsaw 15th Solution
hasibirok0
0
210
ローターアクトEクラブ アメリカンナイト:川端 柚菜 氏(Japan O.K. ローターアクトEクラブ 会長):2720 Japan O.K. ロータリーEクラブ2025年12月1日卓話
2720japanoke
0
460
「コードは上から下へ読むのが一番」と思った時に、思い出してほしい話
panda728
PRO
14
7.3k
これだけで丸わかり!LangChain v1.0 アップデートまとめ
os1ma
6
1.3k
ハイパーメディア駆動アプリケーションとIslandアーキテクチャ: htmxによるWebアプリケーション開発と動的UIの局所的適用
nowaki28
0
340
非同期処理の迷宮を抜ける: 初学者がつまづく構造的な原因
pd1xx
1
580
CloudNative Days Winter 2025: 一週間で作る低レイヤコンテナランタイム
ternbusty
7
1.9k
堅牢なフロントエンドテスト基盤を構築するために行った取り組み
shogo4131
6
1.9k
Featured
See All Featured
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
9
1.1k
Java REST API Framework Comparison - PWX 2021
mraible
34
9k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
120
20k
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
35
2.3k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
359
30k
Keith and Marios Guide to Fast Websites
keithpitt
413
23k
Faster Mobile Websites
deanohume
310
31k
Balancing Empowerment & Direction
lara
5
780
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
31
9.8k
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
659
61k
Code Reviewing Like a Champion
maltzj
527
40k
Improving Core Web Vitals using Speculation Rules API
sergeychernyshev
21
1.3k
Transcript
DDDモデリング勉強会 第6回 2016/3/18(金) 19:00 – 20:00
DDDモデリング勉強会について 【目的】 • 「エリック・エヴァンスのドメイン駆動設計(DDD本)」を題材と して、DDDの勉強をする • 興味のあるテーマについて、講義+実践(モデリング)を通し て、DDDの手法を理解する • DDD本に完全準拠で進めるわけではなく、自分たちの考えを
含める 1
DDDモデリング勉強会について 【過去の開催】 #1 DDDの基礎(講義) #2 DDDの基礎(モデリング) #3 DDDの基礎(グループモデリング) #4 エンティティ、値オブジェクト(グループモデリング)
#5 エンティティ、値オブジェクト(レビュー) 2
アジェンダ • 境界付けられたコンテキスト • コンテキストマップ • コンテキストマップを作ってみる • コンテキストマップを使ってみる 3
アジェンダ • 境界付けられたコンテキスト • コンテキストマップ • コンテキストマップを作ってみる • コンテキストマップを使ってみる 4
境界付けられたコンテキスト • ドメインモデルがどこに属するか • ドメインモデルが通用する範囲 • ユビキタス言語の境界 5
境界づけられたコンテキスト アカウント 銀行取引コンテキスト アカウント ユーザ管理コンテキスト 口座のこと 顧客の財務状況をあらわす システムへログインするユーザーのこと 6
境界はどうやって決めるのか? • 初めから完全に線は引けない • ドメインエキスパートとの会話をしつつ必要に応じて 概念を整理していく – 会話やモデルの語彙に違和感がある • 同じ「言葉」別の「意味」
• 違う「言葉」同じ「意味」 • 別のコンテキストにも同じような語彙がある – モデルの見た目に違和感がある • 他から参照されないエンティティがある • 多数のエンティティに保持されているエンティティがあ る。 7
アジェンダ • 境界付けられたコンテキスト • コンテキストマップ • コンテキストマップを作ってみる • コンテキストマップを使ってみる 8
コンテキストマップって? • 境界付けられたコンテキストが全体でどのよ うな位置づけにいるのかを把握するツール – 各コンテキスト間の関係 – 各コンテキストに含まれるドメイン – 各コンテキストに含まれるドメイン間の関係
(関心 対象の部分を切り出す) – 表現は自由(ホワイトボード等に書いても良い) 9
コンテキストマップを作る目的 現状をコンテキストマップで表現し、戦略的に 改善方向を決定する 現状のコンテキストマップを作る 問題を把握する 問題の改善方法を決める 問題を改善する 繰り 返す 10
Cコンテキスト コンテキストマップの例 U D U D U D Bコンテキスト Aコンテキスト
ACL OHS/PL U:上流(upstream) D:下流(downstream) OHS:公開ホストサービス(open host service) PL:公表された言語(public language) ACL:腐敗防止層(anticorruption layer) A1ドメイン A2ドメイン Cドメイン Bドメイン 11
アジェンダ • 境界付けられたコンテキスト • コンテキストマップ • コンテキストマップを作ってみる • コンテキストマップを使ってみる 12
コンテキストマップを作ってみる • 随時作る • 作ったものは捨てる • 簡単に書けそうなところから手をつける • 適当でもいいから書いてみる 理想形ではなく、あくま
で現状を表現する 13
次のシナリオで実際に作ってみよう • 自社製品と他社製品の販売をしている会社 の既存の業務システムを段階的にリプレイス する • 販売管理サブシステムと在庫管理サブシステ ムをリプレイスする • 人事管理、製造管理、会計管理サブシステム
は今回のリプレイス対象外 14
コンテキストが分かれそうなのは・・ • サブシステム • 外部システム • パッケージ製品 • 業務の組織構造 •
ソースのパッケージ • 開発体制 etc. 通常のプロジェクト では、コンテキスト があいまい 15
開発対象外 開発対象 最初はサブシステムでわけてみる 在庫管理 コンテキスト 販売管理 コンテキスト 生産・製造管理 コンテキスト 会計管理
コンテキスト 人事管理 コンテキスト 16
コンテキストマップをつくる 販売管理 コンテキスト 会計管理 コンテキスト 人事管理 コンテキスト 生産・製造管理 コンテキスト 在庫管理
コンテキスト ACL ACL ACL PL U U D D パッケージ製品 17
アジェンダ • 境界付けられたコンテキスト • コンテキストマップ • コンテキストマップを作ってみる • コンテキストマップを使ってみる 18
問題かもしれない箇所を見つける コンテキスト間に双方向の依存があるが・・ 他にも・・ – ログイン管理・ユーザ管理とかどこ? – 管理会計は? 正しい依存かを検証する 19
販売管理コンテキスト 受注 顧客 発注 請求 在庫管理コンテキスト 在庫 コンテキストのドメインを洗い出す 20
販売管理に発注と受注のドメインが含まれてい るためだった 双方向依存の原因は? 発注業務は、他社からの購買なので自社の製 品を売る販売管理とは違うコンテキストのはず 21
この問題を改善するためには 販売管理コンテキスト 受注 顧客 請求 在庫管理コンテキスト 在庫 購買管理コンテキスト 発注 22
改善した結果・・ 販売管理 コンテキスト 会計管理 コンテキスト 人事管理 コンテキスト 生産・製造管理 コンテキスト 在庫管理
コンテキスト ACL ACL ACL PL U D パッケージ製品 購買管理 コンテキスト ACL U D D U 23
DDDモデリング勉強会について 【今後の予定】 #7 コンテキストマップ(モデリング) 5月 (1) お題をもとにコンテキストマップを作ってみる (2) 作ったコンテキストマップから問題を見つける #8
ドメインイベント(講義) 7月 #9 ドメインイベント(モデリング) 9月 24