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
RDRA/DDD/Goでモジュラーモノリスのアプリを開発してみた話 / developing ...
Search
Imamoto Hikaru
July 24, 2023
Technology
2.7k
3
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
RDRA/DDD/Goでモジュラーモノリスのアプリを開発してみた話 / developing a modular monolith application with RDRA DDD Go
Imamoto Hikaru
July 24, 2023
More Decks by Imamoto Hikaru
See All by Imamoto Hikaru
日々のSlackアラート確認運用をCustom Chat Modesで楽にした話 / 日々のSlackアラート確認運用をCustom Chat Modesで楽にした話
imamotohikaru
0
1.1k
実践!RDRAを活用した既存システムの仕様変更 / Specification Changes in Existing Systems Utilizing RDRA
imamotohikaru
1
8.1k
SRE課が開発中システムのCI/CDで取り組んでいるGitOpsの話 / GitOps with ArgoCD
imamotohikaru
1
2k
RDRAとDDDでGoのモジュラーモノリスアプリを設計してみた話
imamotohikaru
2
3.9k
Other Decks in Technology
See All in Technology
iAEONの段階的リアーキテクト戦略 / iAEON's_Gradual_Re-architecture_Strategy
aeonpeople
0
230
2026TECHFRESH畢業分享會 - 葬送的通靈師:化系統與用戶雜訊成行動訊號
line_developers_tw
PRO
0
1.3k
【セミナー資料】Claude Code をセキュアに使うための考え方と設定の勘どころ / Claude Code Webinar 20260616
masahirokawahara
2
420
AI時代のコスト管理を考えよう〜明日から使える実践AWSノウハウ~
yoshimi0227
0
310
[チョークトーク資料]AWS DevOps Agent を使いこなす / AWS Dev Ops Agent Chalk Talk AWS Summit Japan 2026
kinunori
3
580
【NRUG vol.18】KubernetesにおけるNew Relicデータ取得量削減の考え方
nrug_member
0
170
Bucharest Tech Week 2026 - Guardians of the Cloud-Native Galaxy
edeandrea
PRO
0
120
2026 TECHFRESH 畢業分享會 - 開發日常大解密!從領域驅動到企業級上線
line_developers_tw
PRO
0
1.3k
Kubernetesにおける学習基盤とLLMOpsの概要
ry
1
320
FPC(フレキシブル)基板にZephyr実装してみた。
iotengineer22
0
120
【Snowflake Summit 2026 Recap!!】Snowflake Summit Deep Dive: Security & Governance
civitaspo
1
270
【2026年版】 ベクトル検索とEmbedding最前線
mocobeta
17
4.6k
Featured
See All Featured
Art, The Web, and Tiny UX
lynnandtonic
304
22k
Hiding What from Whom? A Critical Review of the History of Programming languages for Music
tomoyanonymous
2
860
Making the Leap to Tech Lead
cromwellryan
135
9.9k
Darren the Foodie - Storyboard
khoart
PRO
3
3.4k
[SF Ruby Conf 2025] Rails X
palkan
2
1.1k
SEO Brein meetup: CTRL+C is not how to scale international SEO
lindahogenes
1
2.7k
What does AI have to do with Human Rights?
axbom
PRO
1
2.2k
Groundhog Day: Seeking Process in Gaming for Health
codingconduct
0
210
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
16
2k
My Coaching Mixtape
mlcsv
0
150
GraphQLとの向き合い方2022年版
quramy
50
15k
HU Berlin: Industrial-Strength Natural Language Processing with spaCy and Prodigy
inesmontani
PRO
0
410
Transcript
©2022 RAKUS Co., Ltd. RDRA/DDD/Goで モジュラーモノリスの アプリを開発してみた話 株式会社ラクス 今本光
自己紹介 SI企業でのエンジニア経験を経て 2021/10にラクスに入社。 SRE課所属 趣味:野球観戦、サウナ、日向坂46 Twitter: @imamotohikaru GitHub: @kudagonbe
開発フェーズごとの戦略・アウトプット 要件定義 基本/詳細設計 実装 戦略 アウト プット RDRAを用いた要求分析 ・業務、BUCの洗い出し ・画面、システム機能の洗い出し
・要求元との要件合意の迅速化 RDRA資料を利用してDDD ・RDRAの業務分割を前提としたコン テキスト分割 ・RDRAと同じドメイン名 ・コンテキスト単位で設計資料作成 Goでモジュラーモノリス ・コンテキストごとに Go modulesを割 り当て(Workspace Mode使用) ・moduleごとにレイヤードアーキテク チャで実装 RDRAの 各種ダイアグラム コンテキストマップ コンテキストごとの 設計資料 Goプログラム
開発フェーズごとの戦略・アウトプット 要件定義 基本/詳細設計 実装 戦略 アウト プット RDRAを用いた要求分析 ・業務、BUCの洗い出し ・画面、システム機能の洗い出し
・要求元との要件合意の迅速化 RDRA資料を利用してDDD ・RDRAの業務分割を前提としたコン テキスト分割 ・RDRAと同じドメイン名 ・コンテキスト単位で設計資料作成 Goでモジュラーモノリス ・コンテキストごとに Go modulesを割 り当て(Workspace Mode使用) ・moduleごとにレイヤードアーキテク チャで実装 RDRAの 各種ダイアグラム コンテキストマップ コンテキストごとの 設計資料 Goプログラム
要件定義フェーズ
RDRAを用いた要求分析 • RDRA(リレーションシップ駆動要求分析)とは ◦ 神崎善司さん(@zenzengood)が提唱している要件分析手法 ◦ 上位の「レイヤー」から要求分析をスタートして、徐々に下位の「レイヤー」に 向けて要件を詳細化していく ◦ レイヤーごとに「アイコン」というモデルを用いて「ダイアグラム」という成果
物を作成する
RDRAに関する概念①:レイヤー システム価値 役割 具体的な 作業 システムが 「誰にとっての価値を 実現するのか」 を明らかにする 関連するアクター、
外部システム、 システム化目的等を定義 システム外部環境 システム境界 システム システムが 「どのように使われる のか」 を明らかにする システムと 「どう関わるか」 を明らかにする システムそのものを 表現する 業務、 ビジネスユースケースを洗 い出し、 業務フローや利用ケース を定義する 誰がどのようにシステムを 利用するか (画面・イベント)や システムの処理の単位 (ユースケース)を定義す る システム化する 「情報」と その情報が取り得る 「状態」で システムを明示する 上位 下位 レイヤー名
上位レイヤーを入力として下位レイヤー作業を実施する システム価値 役割 具体的な 作業 システムが 「誰にとっての価値を 実現するのか」 を明らかにする 関連するアクター、
外部システム、 システム化目的等を定義 システム外部環境 システム境界 システム システムが 「どのように使われる のか」 を明らかにする システムと 「どう関わるか」 を明らかにする システムそのものを 表現する 業務、 ビジネスユースケースを洗 い出し、 業務フローや利用ケース を定義する 誰がどのようにシステムを 利用するか (画面・イベント)や システムの処理の単位 (ユースケース)を定義す る システム化する 「情報」と その情報が取り得る 「状態」で システムを明示する Input Input Input 上位 下位 レイヤー名
上位レイヤーは下位レイヤーの「WHY」になっている システム価値 役割 具体的な 作業 システムが 「誰にとっての価値を 実現するのか」 を明らかにする 関連するアクター、
外部システム、 システム化目的等を定義 システム外部環境 システム境界 システム システムが 「どのように使われる のか」 を明らかにする システムと 「どう関わるか」 を明らかにする システムそのものを 表現する 業務、 ビジネスユースケースを洗 い出し、 業務フローや利用ケース を定義する 誰がどのようにシステムを 利用するか (画面・イベント)や システムの処理の単位 (ユースケース)を定義す る システム化する 「情報」と その情報が取り得る 「状態」で システムを明示する WHY WHY WHY 上位 下位 レイヤー名
• アイコン ◦ レイヤーごとに定義されるモデル • ダイアグラム ◦ レイヤーごと明らかにすべき事柄を 示すための図 •
例:システムコンテキスト図 ◦ システム価値レイヤーで定義されるダ イアグラム ◦ システムに関わるアクター、外部シス テムをアイコンとして定義する ◦ システム化の目的を認識合わせする RDRAに関する概念②:アイコン・ダイアグラム
今回作成した ダイアグラム • 「業務フロー+UC複合図」のみ複数 レイヤーを跨ぐダイアグラム • draw.ioで作図し、 GoogleSpreadSheetに集約 • それぞれの詳しい説明はRDRA2.0
ハンドブック 等をご参照ください。
RDRAを実践してみた感想 • 「要件定義」にとどまらず「基本設計」まで踏み込んだドキュメント が完成される ◦ 内容が具体的になるので要求元との要件合意がより迅速・明確にできる • 「業務」や「ビジネスユースケース」の分割は難しい ◦ 試行錯誤して決定する必要がある
• ビジネスとシステムのバランス感覚が必要 ◦ システムに寄りすぎると、ビジネス側の人に内容を理解してもらえない
開発フェーズごとの戦略・アウトプット 要件定義 基本/詳細設計 実装 戦略 アウト プット RDRAを用いた要求分析 ・業務、BUCの洗い出し ・画面、システム機能の洗い出し
・要求元との要件合意の迅速化 RDRA資料を利用してDDD ・RDRAの業務分割を前提としたコン テキスト分割 ・RDRAと同じドメイン名 ・コンテキスト単位で設計資料作成 Goでモジュラーモノリス ・コンテキストごとに Go modulesを割 り当て(Workspace Mode使用) ・moduleごとにレイヤードアーキテク チャで実装 RDRAの 各種ダイアグラム コンテキストマップ コンテキストごとの 設計資料 Goプログラム
基本/詳細設計フェーズ
RDRA資料を利用してDDD 戦略的DDDを実践 • コンテキストマップの作成 ◦ RDRAの「ビジネスコンテキスト」「業務フロー+UC複合図」を主なインプットとして、 分割できる業務領域を洗い出して境界付けられたコンテキストを定義 • ユビキタス言語となる用語集の作成 ◦
RDRAの「情報モデル」を主なインプットとして、コンテキストごとに「用語説明」とい う形で主なユビキタス言語を付記
コンテキストマップの イメージ コンテキストごとの名前・責務・情報・用語説明 を整理し、 コンテキスト間の依存関係を矢印で図示。 コンテキスト間が相互依存・循環参照にならな いようにコンテキストを分割する。
コンテキストごとの設計資料 レイヤードアーキテクチャの各層に対応する資料を作成 (コンテキストごとにレイヤードアーキテクチャ構成をとる想定のため) • Domain層 → ドメインモデル図 • UserInterface層、Application層 →
シーケンス図 • Infrastructure層 → テーブル設計
DDDを実践してみた感想 • 前フェーズのRDRAの資料をインプットとして活用できた点が良かった ◦ RDRAで基本設計まで踏み込んでいるので、モデリングがしやすかった • テキストベースでの用語説明や設計意図説明も残しておいた方が良い • mermaid.jsを使ってmarkdownファイル内で書いたので、レビューもし てもらいやすかった
◦ GitHubがmermaidの自動レンダリングに対応している
開発フェーズごとの戦略・アウトプット 要件定義 基本/詳細設計 実装 戦略 アウト プット RDRAを用いた要求分析 ・業務、BUCの洗い出し ・画面、システム機能の洗い出し
・要求元との要件合意の迅速化 RDRA資料を利用してDDD ・RDRAの業務分割を前提としたコン テキスト分割 ・RDRAと同じドメイン名 ・コンテキスト単位で設計資料作成 Goでモジュラーモノリス ・コンテキストごとに Go modulesを割 り当て(Workspace Mode使用) ・moduleごとにレイヤードアーキテク チャで実装 RDRAの 各種ダイアグラム コンテキストマップ コンテキストごとの 設計資料 Goプログラム
実装フェーズ
Goでモジュラーモノリス • Goには「module」というコード管理 単位が存在 • Workspace modeを利用し、複数 のmoduleをモノレポで管理するモ ジュラーモノリス構成を取る事が可能 Main
Module Module A Module B Main Module Workspace 管理
参考:GoのWorkspace mode • Go1.18から導入 • Moduleの解決をgo.workファイルに記述できる
実装の基本方針 • コンテキストマップと同じ粒度でGo Moduleを作成することで、モジュラーモ ノリスを実現する ◦ Moduleの名前や依存関係はコンテキストマップを踏襲 ◦ 1つのリポジトリ(モノレポ)で複数Moduleを管理し、同一リポジトリ内のModuleにも依存可能 •
Moduleごとにレイヤードアーキテクチャ構成にする • コンテキストごとにDBも分割 ◦ PostgreSQLで同一DBクラスタで複数DBを作成 • その他の細かい実装方針は以下のStyleGuideでも公開しています ◦ https://github.com/rakus-public/styleguide/tree/main/go
未来の話:モジュラーモノリスをMSA化 • MSA化する場合はModuleを別リポジトリに切り出すことで実現可能 ◦ 切り出すModuleに対して外部呼び出し用のAPIを準備 ◦ 切り出したModuleに対して行っていたメソッド呼び出しを、API呼び出しに切り替 える ◦ DBは既に分離済みのため、大きなマイグレーション不要
Goでモジュラーモノリスを実践してみた感想 • DDDの境界づけられたコンテキストがソースコードにも対応づけられる ので、要件定義・基本/詳細設計フェーズとの一貫性が出て良かった • モジュラーモノリス構成を実現するのにGoは適した言語だと思った • GoでDDDを実践するための実装手法については手探りになる場面が 多く、今後もブラッシュアップが必要
交通費・経費精算 システム 勤怠管理システム コールセンター向けCRM システム 問い合わせ管理 システム メールマーケティングサービ ス 販売管理業務
システム 電子請求書発行・電子保存 システム 社内向け AIチャットボット BtoB SaaSのマルチヒットメーカーとして成長中! 企業の業務の効率化、付加価値化に貢献する複数のサービスを展開!
ご清聴ありがとうございました