中國培訓(xùn)易(m.a10by9.cn) 研發(fā)項目公開課 

 

 

 


  

  

主辦單位:廣州必學(xué)企業(yè)管理咨詢有限公司
      中國培訓(xùn)易(m.a10by9.cn)

舉辦時間:
深圳 2015年5月30–31日

課程費用:5800元/人(含資料費、授課費、發(fā)票)
會 員 價:會員優(yōu)惠價請咨詢客服, QQ:674837974 手機/微信:18588851172 符小姐

內(nèi)容提示
領(lǐng)域驅(qū)動設(shè)計課程培訓(xùn),內(nèi)容涉及領(lǐng)域建模的方法,領(lǐng)域驅(qū)動設(shè)計的戰(zhàn)略設(shè)計,領(lǐng)域驅(qū)動設(shè)計的架構(gòu)設(shè)計,領(lǐng)域驅(qū)動設(shè)計的戰(zhàn)術(shù)設(shè)計等,通過真實案例的演練,熟悉開發(fā)過程與設(shè)計方法,采用最新的領(lǐng)域驅(qū)動設(shè)計思想與方法,并輔以可視化的設(shè)計手段,以工作坊的形式開展培訓(xùn),以便于學(xué)員更好地理解領(lǐng)域驅(qū)動設(shè)計。



課程詳情

課程目標(biāo)
需求分析人員和領(lǐng)域?qū)<覠o法與團隊的設(shè)計人員和開發(fā)人員進行有效溝通。需求分析人員不了解軟件設(shè)計,軟件設(shè)計人員常常會曲解需求內(nèi)容,這是軟件開發(fā)中容易出現(xiàn)的第一病癥。它帶來的后果是設(shè)計頻繁變更,設(shè)計的軟件不滿足客戶需求。

需求分析雖然明白無誤,設(shè)計人員卻無法準(zhǔn)確地抽象領(lǐng)域模型,從而不能開展有效的軟件設(shè)計,這是軟件開發(fā)中容易出現(xiàn)的第二病癥。它帶來的后果是設(shè)計質(zhì)量糟糕,開發(fā)的代碼不具有良好的可讀性,增加了軟件的開發(fā)與維護成本。

系統(tǒng)的業(yè)務(wù)需求復(fù)雜多變,設(shè)計人員卻總是喜歡從實現(xiàn)角度以及數(shù)據(jù)庫層面思考業(yè)務(wù)問題,這是軟件開發(fā)中容易出現(xiàn)的第三病癥。它會導(dǎo)致開發(fā)的系統(tǒng)過于復(fù)雜,且可擴展性差,無法有效應(yīng)對需求發(fā)生的變化。

本次培訓(xùn)的內(nèi)容——領(lǐng)域驅(qū)動設(shè)計正好是解決這三種常見病癥的最佳藥方。

培訓(xùn)特色
思想為體,方法為用,貫徹卓越軟件設(shè)計之精神,而非流于表面形式;
提倡開放的設(shè)計觀,不局限于一種設(shè)計方法學(xué),而是融匯貫通,取長補短;

重視案例分析與實踐,提倡動手實驗,而非單純以講授性質(zhì)的培訓(xùn);通過真實案例的演練,熟悉開發(fā)過程與設(shè)計方法;

采用最新的領(lǐng)域驅(qū)動設(shè)計思想與方法,并輔以可視化的設(shè)計手段,以工作坊的形式開展培訓(xùn),以便于學(xué)員更好地理解領(lǐng)域驅(qū)動設(shè)計;

編碼與設(shè)計,二者不可偏廢。沒有優(yōu)秀的個人設(shè)計能力,團隊就會成為無根之木,無法保證軟件的高質(zhì)量。必須幫助團隊的每個人都能熟練運用領(lǐng)域驅(qū)動的分析與設(shè)計能力,才能保證生產(chǎn)力的高效;


課程大綱
第一單元 領(lǐng)域建模的方法
1、領(lǐng)域建模與設(shè)計的關(guān)系
優(yōu)秀的軟件系統(tǒng)與好的軟件設(shè)計息息相關(guān),但最關(guān)鍵的還是在于對需求的理解。如果 不能正確的理解軟件需求,那么再好的設(shè)計也不能設(shè)計出好的軟件。正確的做事情固然重要,更重要的是要做正確的事。然而,需求到設(shè)計存在巨大的鴻溝,因為需求是站在業(yè)務(wù)角度來考慮,而設(shè)計往往會站在實現(xiàn)角度。領(lǐng)域建模就是為這二者搭建一個溝通與轉(zhuǎn)換的橋梁。
2、領(lǐng)域建模從需求開始
為了更好的理解需求,我們可以從需求畫布開始,充分理解參與軟件系統(tǒng)的角色、功能、價值等內(nèi)容,以便于整個團隊更為深入地理解需求,達成一致認識。
演練:繪制商業(yè)需求畫布
3、場景驅(qū)動設(shè)計模型
場景驅(qū)動設(shè)計的核心在于識別場景,它需要設(shè)計者結(jié)合具體的業(yè)務(wù)場景,分析業(yè)務(wù)流 程,以此驅(qū)動出用例;再以用例驅(qū)動對業(yè)務(wù)邏輯的建模。場景驅(qū)動設(shè)計的核心模型為6W模型,即Who,Why,When,What,Where與hoW。它 將對應(yīng)職責(zé)模型的業(yè)務(wù)價值、業(yè)務(wù)功能與業(yè)務(wù)實現(xiàn),并從角色的角度思考對象之間的協(xié)作以及設(shè)計邊界。
演練:繪制場景圖

第二單元 領(lǐng)域驅(qū)動設(shè)計的戰(zhàn)略設(shè)計
1、限界上下文
若要進行領(lǐng)域建模,并將業(yè)務(wù)需求逐步演化為架構(gòu)設(shè)計,則需要引入DDD(領(lǐng)域驅(qū) 動設(shè)計)的戰(zhàn)略設(shè)計作為指導(dǎo)。場景圖與限界上下文可以很好地結(jié)合,幫助架構(gòu)師很好地識別各個子領(lǐng)域的概念邊界與設(shè)計邊界。如此則可以運用“分而治之”的思想識別出整個系統(tǒng)的業(yè)務(wù)邏輯邊界與物理邊界。
可視化演練:識別電子商務(wù)系統(tǒng)的限界上下文
2、領(lǐng)域模型
通過限界上下文,可以幫助我們分析系統(tǒng)的領(lǐng)域模型,包括系統(tǒng)的核心領(lǐng)域與子領(lǐng) 域。確定系統(tǒng)的核心領(lǐng)域與子領(lǐng)域可以幫助架構(gòu)師合理分配資源(包括時間資源與人力資源)。而對子領(lǐng)域的進一步識別,可以幫助架構(gòu)師更好地識別可重用資源,包括可重用的功能模塊,確定技術(shù)棧,決定構(gòu)建還是購買的架構(gòu)戰(zhàn)略。
3、四色建模法
首先以滿足管理和運營的需要為前提,尋找需要追溯的事件。根據(jù)這些需要追溯,尋找足跡以及相應(yīng)的時標(biāo)性對象。尋找時標(biāo)對象周圍的人/事/物。從中抽象角色,把一些信息用描述對象補足。
案例分析:配送管理系統(tǒng)的四色建模
4、上下文映射圖
本部分內(nèi)容會講解限界上下文之間主要存在的組織模式與集成模式,這其中包括防腐層,開放服務(wù)調(diào)用等。利用上下文映射圖,有助于識別上下文之間的關(guān)系,思考處于上下文內(nèi)領(lǐng)域模型之間的通信方式,從而幫助架構(gòu)師驅(qū)動出最終的應(yīng)用邏輯架構(gòu)。
可視化演練:電子商務(wù)系統(tǒng)的應(yīng)用邏輯架構(gòu)

第三單元 領(lǐng)域驅(qū)動設(shè)計的架構(gòu)設(shè)計
1、分層架構(gòu)
分層架構(gòu)模式是應(yīng)用最為廣泛的架構(gòu)模式,它根據(jù)關(guān)注點分離的架構(gòu)原則,針對表現(xiàn)層、領(lǐng)域?qū)雍突A(chǔ)設(shè)施層進行層次分離。本次培訓(xùn)將以全新視角審視分層架構(gòu),針對大型軟件系統(tǒng)分析該如何進行分層架構(gòu)設(shè)計。
案例分析:網(wǎng)上銀行的分層架構(gòu),根據(jù)最基本的業(yè)務(wù)流程對系統(tǒng)進行關(guān)注點分離,繪制系統(tǒng)的分層架構(gòu),并通過時序圖展現(xiàn)各層之間的協(xié)作。
2、六邊形架構(gòu)
雖然分層架構(gòu)仍然是運用最為廣泛的架構(gòu)模式,同時更是諸多架構(gòu)模式的基礎(chǔ),但它 已不足以描述越來越復(fù)雜的分布式系統(tǒng)架構(gòu)。由Cockburn提出的六邊形架構(gòu)(Hexagonal Architecture)是一種具有對稱性特征的架構(gòu)風(fēng)格。在這種架構(gòu)中,不同的客戶通過“平等”的方式與系統(tǒng)交互。該架構(gòu)中存在兩個區(qū)域,分別是“外部區(qū)域”和“內(nèi)部區(qū)域”。這種界定了明確內(nèi)外邊界的架構(gòu)風(fēng)格,更有利于架構(gòu)師實現(xiàn)關(guān)注點分離,并將關(guān)注重心放在適配器與通信端口上。
演練:六邊形架構(gòu)的通信邊界
案例:大型金融系統(tǒng)的客戶管理
3、CQRS
CQRS風(fēng)格,即命令查詢職責(zé)分離(Command Query ResponsibilitySegregation),它結(jié)合了消息處理、事件處理的架構(gòu)風(fēng)格,是對多種設(shè)計模式的綜合運用,適用于處理讀寫比例高,需要支持可伸縮性的大型系統(tǒng)。
案例:AxonFramework對CQRS的支持
4、事件驅(qū)動架構(gòu)
事件驅(qū)動架構(gòu)(Event-Driven Architecture,EDA)是一種用于處理事件生成、發(fā)現(xiàn)和處理等任務(wù)的軟件架構(gòu)。事件往往對應(yīng)于軟件系統(tǒng)的狀態(tài)機,狀態(tài)的遷移就是用事件來觸發(fā)的。因而,事件能夠很好地體現(xiàn)這樣的業(yè)務(wù)模型。同時,基于事件的軟件架構(gòu)可以幫助我們更好地建立松散耦合的模塊化架構(gòu)。

第四單元 領(lǐng)域驅(qū)動設(shè)計的戰(zhàn)術(shù)設(shè)計
1、領(lǐng)域驅(qū)動設(shè)計的專用術(shù)語
領(lǐng)域驅(qū)動設(shè)計的一個特點是針對領(lǐng)域?qū)樱岢隽私y(tǒng)一的設(shè)計術(shù)語,包括關(guān)聯(lián)、實體、值對象、聚合、服務(wù)、模塊。注意區(qū)分它與傳統(tǒng)業(yè)務(wù)層設(shè)計在概念上的區(qū)別。甄別這些概念之間的區(qū)別,有利于我們正確地運用領(lǐng)域驅(qū)動設(shè)計。
整體而言,領(lǐng)域驅(qū)動設(shè)計的這些術(shù)語涵蓋了領(lǐng)域?qū)ο蟮恼麄生命周期,包括領(lǐng)域?qū)ο髲膭?chuàng)建、存儲、重建、歸檔、修改到刪除的整個生命周期。
2、實體與值對象
這兩個概念都是領(lǐng)域?qū)ο蟮捏w現(xiàn),二者的主要區(qū)別在于對“標(biāo)識”的運用。本部分的內(nèi)容深入展開對實體標(biāo)識的討論,揭示實體的本質(zhì)特征,挖掘?qū)嶓w的關(guān)鍵行為。通過識別角色與職責(zé)對實現(xiàn)進行分析。
本部分內(nèi)容還將通過深入講解值對象的特征幫助我們分辨值對象與實體,使得我們可以在領(lǐng)域驅(qū)動設(shè)計中有效地運用實體與值對象。本部分內(nèi)容還包括持久化值對象,以及領(lǐng)域驅(qū)動設(shè)計與ORM之間的關(guān)系。
3、領(lǐng)域服務(wù)
通過講解什么是領(lǐng)域服務(wù),什么不是領(lǐng)域服務(wù)理清領(lǐng)域服務(wù)的概念,并講解如何建模領(lǐng)域服務(wù)。討論領(lǐng)域服務(wù)和面向接口設(shè)計思想。
4、領(lǐng)域事件
事件驅(qū)動架構(gòu)的主要對象即為領(lǐng)域事件,我們要分清在何時以及為什么要使用領(lǐng)域事件,并對領(lǐng)域事件進行建模。通過講解發(fā)布者-訂閱者模式講解如何在領(lǐng)域模型和限界上下文中發(fā)布領(lǐng)域事件。同時,針對事件進行存儲的EventSource也與CQRS架構(gòu)風(fēng)格直接相關(guān)。
5、模塊
模塊化設(shè)計是優(yōu)良架構(gòu)的保障,同時也是軟件復(fù)用最重要的單元。領(lǐng)域驅(qū)動設(shè)計將模塊視為與對象相等的一等公民,這使得整個設(shè)計在微觀層面符合面向?qū)ο蟮乃枷,同時也能夠為宏觀層面的架構(gòu)設(shè)計提供有力地支持。本部分將結(jié)合限界上下文講解基本的模塊設(shè)計原則與設(shè)計模式。
6、聚合
聚合是領(lǐng)域驅(qū)動設(shè)計最為重要的領(lǐng)域概念。本部分內(nèi)容將深入探討聚合的設(shè)計原則,并辨別在聚合設(shè)計中可能出現(xiàn)的壞味道,并提出針對性的解決方案。這些原則和方案包括:在一致性邊界之內(nèi)建模真正的不變量,設(shè)計小的聚合,通過唯一標(biāo)識引用其他聚合,在邊界外滿足最終一致性。
7、工廠和資源庫
工廠和資源庫都是管理領(lǐng)域?qū)ο螅▽嶓w、值對象和服務(wù))生命周期的對象。工廠主要針對內(nèi)存中對象從無到有的創(chuàng)建過程,與設(shè)計模式的工廠模式基本相似。
資源庫則分為面向集合的資源庫與面向持久化的資源庫。本部分內(nèi)容將重點講解與資源庫直接相關(guān)的技術(shù)細節(jié),包括如何選擇資源庫的方式,如何針對聚合持久化資源庫,如何管理事務(wù),以及分辨資源庫與數(shù)據(jù)訪問對象(DAO)之間的異同。
8、應(yīng)用層設(shè)計
作為為UI提供的應(yīng)用服務(wù),其目的在于管理和協(xié)調(diào)領(lǐng)域?qū)ο螅轭I(lǐng)域?qū)ο筇峁M 切關(guān)注點的內(nèi)容。好的應(yīng)用服務(wù)設(shè)計不應(yīng)該承擔(dān)任何與領(lǐng)域邏輯有關(guān)的職責(zé)。應(yīng)用層是架構(gòu)層面的外觀與適配器模式的體現(xiàn)。它可以提高軟件系統(tǒng)架構(gòu)的可用性與簡單性,也能夠更好地與面向服務(wù)架構(gòu)或RESTful架構(gòu)風(fēng)格結(jié)合。

第五單元 實戰(zhàn)演練
基于多租戶的社交網(wǎng)絡(luò)系統(tǒng)以及項目管理系統(tǒng)的領(lǐng)域驅(qū)動設(shè)計
這是領(lǐng)域驅(qū)動設(shè)計過程的完整案例分析,從需求開始著手,開展對整個系統(tǒng)的架構(gòu)分析、領(lǐng)域概念識別與分析,并對建立的領(lǐng)域模型進行迭代與演化,核心領(lǐng)域概念的演進,掃清領(lǐng)域設(shè)計過程中的認知障礙,并總結(jié)了領(lǐng)域驅(qū)動設(shè)計過程的一些經(jīng)驗教訓(xùn)。
本實戰(zhàn)演練包含了真實的案例需求,以及符合領(lǐng)域驅(qū)動設(shè)計各種知識點的案例病癥分析,從對比入手來探討好的領(lǐng)域驅(qū)動設(shè)計方法。同時,還將引入大量的可視化圖形、設(shè)計圖與代碼幫助學(xué)員理解如何在真實項目中運用領(lǐng)域驅(qū)動設(shè)計的思想,指導(dǎo)設(shè)計人員進行良好的設(shè)計。


講師簡介

  Bruce Zhang 老師
擅長領(lǐng)域
研發(fā)管理

職業(yè)背景
高級咨詢師,軟件架構(gòu)師,敏捷教練,連續(xù)四屆榮獲微軟最有價值專家,InfoQ 架構(gòu)社區(qū)常務(wù)編輯。先后任職于惠普、中興通訊、中軟國際等企業(yè),擔(dān)任高級軟件工程師、系統(tǒng)架構(gòu)師、技術(shù)總監(jiān)等職務(wù)。

擁有15年的軟件開發(fā)與8年左右的軟件架構(gòu)設(shè)計經(jīng)驗,主要專注于軟件架構(gòu)、設(shè)計模式、測試驅(qū)動開發(fā)、重構(gòu)、領(lǐng)域驅(qū)動設(shè)計和敏捷開發(fā),以及基于Java/.NET平臺的企業(yè)級系統(tǒng)應(yīng)用開發(fā)和分布式開發(fā)。

多次應(yīng)邀參加國內(nèi)具有影響力的軟件開發(fā)大會,包括QCon全球企業(yè)開發(fā)大會,亞太軟件軟件研發(fā)團隊管理年會、Scrum Gathering、Agile China以及中國軟件技術(shù)大會,擔(dān)任大會主持人、制作人和講師。著譯作包括《軟件設(shè)計精要與模式》、《WCF服務(wù)編程》、《Java設(shè)計模式》、《恰如其分的軟件架構(gòu)》

授課經(jīng)驗
作為咨詢師和培訓(xùn)師,曾先后為可口可樂、摩托羅拉、HP、盛大、第九城市、CA、攜程、中興通訊等企業(yè)提供咨詢與培訓(xùn)服務(wù)。


課程對象


   注


課程名稱:領(lǐng)域驅(qū)動設(shè)計

 


咨詢電話020-29042042      QQ 59870764
網(wǎng)上查詢中國培訓(xùn)易 http://m.a10by9.cn


     執(zhí)  

為確保您的報名名額和及時參加,請?zhí)崆皩⒋耍▓竺恚?/font>E-mail至674837974@QQ.com;721560397@QQ.COM(符小姐、黃小姐)我們將有專人與您聯(lián)系確認,并于開課前發(fā)出《培訓(xùn)報名確認函》。培訓(xùn)時間、地點、住宿等詳細信息請以《培訓(xùn)報名確認函》書面通知為準(zhǔn),敬請留意。謝謝!

聯(lián)系人:符小姐    電話:18588851172    QQ:674837974

網(wǎng)址:m.a10by9.cn(中國培訓(xùn)易)

課程名稱:領(lǐng)域驅(qū)動設(shè)計       時間地區(qū):_____________

公司全稱: 

聯(lián)系人

 

部門

 

公司網(wǎng)址

 

聯(lián)系電話

 

傳真

 

聯(lián)系郵箱

 

公司地址

 

郵編

 

參會人數(shù):        

參會人員資料

姓名

職務(wù)

電話

手機

E-mail

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

付款方式: □ 轉(zhuǎn)帳 □ 現(xiàn)金 (請選擇 在□打√) 注:部分地區(qū)不可現(xiàn)金


單位匯款帳戶:(轉(zhuǎn)到該賬戶請一定要用購買方公司賬戶進行公對公轉(zhuǎn)賬)

開戶人: 廣州必學(xué)企業(yè)管理咨詢有限公司

開戶行: 中國農(nóng)業(yè)銀行廣州天銀大廈支行

: 4405 8501 0400 08276

課程金額:__________

住宿要求(費用自理,開課前三天預(yù)訂)

是否需要會務(wù)組協(xié)助安排住宿:  □是   □否  入住天數(shù)(  )天

入住時間  2024             □標(biāo)準(zhǔn)雙人間(  )間    □標(biāo)準(zhǔn)單人間(  )間                                             

發(fā)票信息:

一、增值稅普通發(fā)票(數(shù)電票):

公司名稱(發(fā)票抬頭):

納稅人識別號:

發(fā)票內(nèi)容:1*現(xiàn)代服務(wù)*培訓(xùn)費  2、*現(xiàn)代服務(wù)*咨詢服務(wù)費  3*現(xiàn)代服務(wù)*咨詢費  4、*現(xiàn)代服務(wù)*培訓(xùn)咨詢服務(wù)費

 

二、增值稅專用發(fā)票(數(shù)電票):

公司名稱:

納稅人識別號:

發(fā)票內(nèi)容:1*現(xiàn)代服務(wù)*培訓(xùn)費