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
増田 亨
PRO
January 17, 2022
Programming
4k
4
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
基幹システムの変更を楽で安全にする
大規模な基幹システムの再構築にドメイン駆動設計を適用する取り組みの簡単な紹介です。
増田 亨
PRO
January 17, 2022
More Decks by 増田 亨
See All by 増田 亨
AI 時代のソフトウェア設計の学び方
masuda220
PRO
29
12k
SCSD:事業価値を生み出すソフトウェア開発の実践技法
masuda220
PRO
3
200
AI時代のシステム設計:ドメインモデルで変更しやすさを守る設計戦略
masuda220
PRO
8
1.4k
競争優位を生み出す戦略的内製開発の実践技法
masuda220
PRO
4
700
ソフトウェア設計の課題・原則・実践技法
masuda220
PRO
30
24k
乱雑なコードの整理から学ぶ設計の初歩
masuda220
PRO
38
18k
ドメイン駆動設計のエッセンス
masuda220
PRO
20
8.7k
開発組織の戦略的な役割と 設計スキル向上の効果
masuda220
PRO
13
2.7k
ソフトウェア設計の実践的な考え方
masuda220
PRO
6
1.1k
Other Decks in Programming
See All in Programming
AI時代の仕事技芸論 — ソフトウェア開発で「遊ぶように働く」職人的熟達のすすめ
kuranuki
2
670
DynamoDBには集計系のクエリがないけどなんとかしたい
musan
1
140
Signal Forms: Details & Live Coding @enterJS 2026 in Mannheim
manfredsteyer
PRO
0
120
スマートグラスで並列バイブコーディング
hyshu
0
130
Vue × Nuxt × Oxc どこまで使える?実運用の現在地
andpad
0
240
AIだと陥りがちなJakarta EE最新技術への移行時の落とし穴と解決策
tnagao7
0
110
AIで効率化できた業務・日常
ochtum
0
130
Snowflake Summitでの新機能 CoCo / CoWork / snowflake-summit-2026-overall-what-new-coco
tatsuhiro
1
120
運用エージェントは "作る" から "育てる" へ - 記憶と自己進化の3層設計パターン / self-evolving-agents-three-layer-agent-design
gawa
12
3.7k
決定論的オーケストレーションの設計と実装 / Design and Implementation of Deterministic Orchestration
nrslib
3
1.3k
技術記事、AIに書かせるか、自分で書くか? 〜それでも私が自分の手で書く理由〜 / #QiitaConference
jnchito
2
1.4k
TypeScript+Orvalで実現する型安全かつ堅牢でスケーラブルなマルチチャネル通知基盤 / TSKaigi Night talks ~after conference~
d0riven
0
330
Featured
See All Featured
世界の人気アプリ100個を分析して見えたペイウォール設計の心得
akihiro_kokubo
PRO
71
40k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
360
30k
ラッコキーワード サービス紹介資料
rakko
1
3.6M
Tell your own story through comics
letsgokoyo
1
950
How to Get Subject Matter Experts Bought In and Actively Contributing to SEO & PR Initiatives.
livdayseo
0
140
Lightning talk: Run Django tests with GitHub Actions
sabderemane
0
200
Balancing Empowerment & Direction
lara
6
1.2k
Mobile First: as difficult as doing things right
swwweet
225
10k
The #1 spot is gone: here's how to win anyway
tamaranovitovic
2
1.1k
Have SEOs Ruined the Internet? - User Awareness of SEO in 2025
akashhashmi
0
370
Code Review Best Practice
trishagee
74
20k
Leo the Paperboy
mayatellez
7
1.8k
Transcript
基幹システムの 変更を楽で安全にする 2022年1月17日 有限会社システム設計 増田
基幹システムを作り変える 大手損害保険会社の基幹システム • 開発費用の総額1200億円? 年商2000億円規模の通販会社の基幹システム • 開発費用 数十億円 × 数回
• 年間IT費用 数十億円/年
共通のテーマ • ビジネスの要求に応えるシステム変更スピード向上 • ソフトウェア開発コスト(初期・拡張)の削減 • 修正コストの削減
NRIでの実証実験 現行システム実績 今回の試作 初期開発 開発規模 183 千行 97 千行 設計書ボリューム
153本 1枚 (規定集・マニュアルを使用) 変更要求 への対応 モジュール数 追加3 修正65 追加1 修正2 変更規模 5 千行 9 百行 設計書ボリューム 26 枚 0 枚 (業務マニュアル改訂版を使用) 「NRI ドメイン駆動設計」で検索すると 実験の報告書をダウンロードできます。
実際にどう進めているか
現場でやっていること why の合意形成 「良い設計は悪い設計より変更が楽で安全」 ・悪い設計で失っているものの言語化・数値化 ・良い設計で得られるものの言語化・数値化 how の認識合わせ ・ビジネスルール(計算判断ロジック)中心の構造 ・事実の記録中心のテーブル設計
・一覧網羅ではなく濃淡づけとカテゴライズ what の体験学習 ・ドメインオブジェトを実際に書いて動かす ・イミュータブルなテーブル設計で実際に動かす ・一覧の分類、要点の絞り込み、ノイズの除去
変更を楽に安全にするための設計方針 ドメインモデルパターン 組み立て思考で開発 イミュータブル データモデル トランザクション スクリプトパターン ミュータブル データモデル 分解思考で開発
ドメインモデルパターンへの切り替え トランザクションスクリプトパターン ドメインモデルパターン 入出力中心(画面+データベース操作) ビジネスルール(計算判断ロジック)中心 手続き的なプログラミング (データクラスと機能クラス) オブジェクト指向プログラミング (ロジックとデータのカプセル化) 外部設計書
⇒ 内部設計書 規程集・業務マニュアル⇒クラス設計 入出力項目定義⇒入出力処理の記述 計算判断ロジックの記述⇒必要な入出力
イミュータブルデータモデルへの切り替え ミュータブルデータモデル イミュータブルデータモデル 状態の変更と参照が中心 事実の記録が中心 SELECT FOR UPDATE INSERT DELETE
大きなテーブル 小さなテーブル 制約はずし/制約のがれ 制約の徹底 (主キー・外部キー・一意・NOT NULL)
開発のやり方の切り替え 分解思考で開発 組み立て思考で開発 最終形を確定 最終形を仮置き 機能一覧・画面一覧・テーブル一覧 主要な要素・全体の枠組み・構造の軸 分業・分担 協業・補完 標準化・均一化
重みづけ・濃淡・取捨選択
手を動かして習得・納得・手ごたえ
実際に手を動かして習得する/実証する クラス定義 using Java github issue/project テーブル定義 using DDL 詳細設計書
概念ER図 テーブル定義書 WBS・ガントチャート 機能一覧