初めに
きっかけ
- 新人研修中にDDDとか、PoEAAとかの話が少しだけ出ました。
- ただ、イマイチわからないとの声が多数。
理由
- なぜなら予備知識がたくさん必要だからです。(ほんとに多い)
- これはわからなくて当然。
そこで
- 独断と偏見で、予備知識となる用語を解説します。
- 偏見多いので、より正確な情報は、書籍やWebで調べてね。
この辺を説明します
- UML
- クラス図/シーケンス図
- デザインパータン
- GoF/PoEAA
- 階層化アーキテクチャ
- DDD本のサマリ
知らなきゃいけない知識が多くて面倒だね。
説明しないけど、オブジェクト指向やデータベースとかの知識も必要だよ。
説明前にDDD本のページを見てみよう!!!
DDD本の最初のページ
??? よくわからないね
さっきの図って何?
- 灰色の中心部分はソフトウェア設計のモデリングを表しています。
- モデリングとは図や文字でソフトウェアを表すこと。
- その中でUMLという物が出てきます。
- その他はソースコードの構造や文法。
- ソースコードを実装していると、良く使う構造や文法が出てくる。
- それらを「アーキテクチャ」「デザインパターン」と呼びます。
UML
UML(Unified Modeling Language)って何?
- オブジェクト指向プログラミングが出てきた当たりで流行ったモデリング言語です。
- モデリング言語は「図」や「テキスト」を使ってソフトウェアを表現します。
- 基本設計~詳細設計でよく使われます。設計書出よく出てくる図ですね。
- このUMLですが
- 「実装面倒だな...設計図書いたらシステム出来上がってくれないかな」
- 「そういうの作ればいいんじゃね」
- 「コード自動作成機能って良いよね」
- という流れもあって、ソースコードを自動生成する仕様(Model Driven Architecture:MDA)も追加されましたが...
仕様、制約が増大して「ソースコードを書いた方が早い」となってしまいました...
この手の試みは「ワークフロー自動化」「ランブック自動化」「ノーコード」と名前を変えて、ゾンビのように復活するよ。
クラス図
「エリック・エヴァンスのドメイン駆動設計 7章 言語を使用する:応用例」より
クラス図の詳細はこちらを参照:https://www.itsenka.com/contents/development/uml/class.html
シーケンス図
「エリック・エヴァンスのドメイン駆動設計 9章 暗黙的な概念を明示的にする」より
シーケンス図の詳細はこちらを参照:https://www.itsenka.com/contents/development/uml/sequence.html
デザインパターン
デザインパターンって何?
- オブジェクト指向における、使い勝手の良いソースコードのサンプル集みたいな物。
- 単に「デザインパターン」と言うときは、「GoFデザインパターン」を指します。
- 詳細設計~実装に関する技術になります。間接的に基本設計に関連するところも。
- 結構古い(GoF:1994年, PofEAA:2002年)ものなので、陳腐化しているものもあります。
- 推奨されなくなった物(Singleton)や、そもそも実装が複雑で定義が曖昧だったりします。
- 一部は言語/フレームワークの仕様として取り込まれてます。(Iterator/Decorator)
- また、GoF/PofEAAで使われるのはほとんどがJavaのコードです。
- Javaの言語仕様が、頭に入っていないと意味不明なところがあります。
GoF(Gang of Four)デザインパターン
- 「オブジェクト指向における再利用のためのデザインパターン」という本に記載されています。
- Gang of Fourは4人組という意味で、著者が4人いるため、そう呼ばれています。
- DDD本内で事前説明無しで、この用語が頻発するので調べておいたほうが無難。
PofEAA(Patterns of Enterprise Application Architecture)
- GoFとは別著者、マーティン・ファウラーさんが書いた同名の本で紹介されたデザインパターン
- DDD本の中で詳しく説明しているので読まなくても、なんとなくわかる。
- DDDとPofEAAで、同じ用語で意味が全く違うものがあるので紛らわしいです。
- 日本語訳がひどいらしい。パターンカタログを軽く読むくらいなら良いかも。(参考文献みてね)
例えばPofEAAの「ドメインモデル」は、DDDの「ドメインモデル」と微妙に意味が違うよ。面倒だね。
Facadeパターン(GoF)
Facadeパターンの詳細はこちらを参照:https://www.techscore.com/tech/DesignPattern/Facade
FactoryMethodパターン(GoF)
FactoryMethodパターンの詳細はこちらを参照:https://www.techscore.com/tech/DesignPattern/FactoryMethod
階層化アーキテクチャ
階層化アーキテクチャ(Layered Architecture)
- 名前の通り、階層ごとにモジュールなどで分割されたソフトウェア構造、設計を指します。
- 「n階層アーキテクチャ」や「多層アーキテクチャ」と言われたりします。
- もともとJava EEアプリでよく使われてた概念
- 基本設計から実装に関する技術で、アプリ内の構造に着目しています。
- 階層構造をとるアーキテクチャはほかにも色々
- クリーンアーキテクチャ
- オニオンアーキテクチャ
既存のフレームワークの構造を考慮しないと、導入しても死んじゃうから慎重にね。
DDD本の階層化アーキテクチャ
「エリック・エヴァンスのドメイン駆動設計 4章 ドメインを隔離する」より
DDD本の階層化アーキテクチャ(説明)
「エリック・エヴァンスのドメイン駆動設計 4章 ドメインを隔離する」より
DDD本のサマリ
ドメイン駆動設計(DDD)、用語ざっくり解説
- ドメインって何?
- ここで言うドメインは「業務領域」を指していて、業務に関する知識や情報、フローを含む。
- モデルって何?
- ドメインを表すための、図やテキストを指す。雑に言うと設計書みたいなもの。
- ドメインモデルって何?
- ドメインを書いたモデル。ドメインを理解するための考え方。
- ドメインエキスパートって誰?
- 業務に詳しい人。営業とか、プロダクトオーナー、PdMだったり、社内の人だったりする。
- ユビキタス言語って何?
- 業務で使われる用語。チームメンバやドメインエキスパートが必ず理解できる用語にする。
結局ドメイン駆動設計(DDD)ってなに?
- 雑に言うとこんな感じ
- ドメイン(業務)って難しいから、一発でいいソフトウェアは作れないよ。
- ドメインモデル(設計書)をことあるごとに、洗練させてソフトウェアを更新しようね。
- ドメインモデルを変更したら、ソフトウェアを変更するし、逆もまたしかりだよ。
- デザインパターンとかアーキテクチャって何だったん?
- DDD自体が要件定義~単体テストあたりと、広い範囲について説明しているよ。
- ドメインモデルを作った後、実装についても具体例出すので、この2つも話題が出てくるよ。
- 個人的に面白いのが設計と実装をつなぐ部分。
ここにも書いてあるけど、付け焼き刃は良くないよ。目的と手段をはき違えないでね。
参考文献
- エリック・エヴァンスのドメイン駆動設計
- DDDの正体は実装パターンとモデリングの組み合わせ - パンダのプログラミングブログ
- UML入門 - IT専科
- デザインパターン | TECHSCORE(テックスコア)
- 再考: GoF デザインパターン - Qiita
- 一時期プログラミングのデザインパターンというものが大流行しましたが、現在ではどのように評価されているのでしょうか? - Quora
- GoF デザインパターン チートシート - Qiita
- Patterns of Enterprise Application Architecture