精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

如何形成統(tǒng)一設(shè)計風格-實踐篇

開發(fā) 開發(fā)工具
本篇將總結(jié)團隊近來的架構(gòu)演進工作,以更具體的技術(shù)細節(jié),詳細闡釋該理念,作為“統(tǒng)一業(yè)務(wù)設(shè)計風格”的實踐篇。文中詳述了多個層面的設(shè)計規(guī)約和基于規(guī)約的搭建方式,并在末尾回答了上一篇的諸多疑問。

[[439211]]

一 背景

在上一篇《業(yè)務(wù)團隊如何統(tǒng)一架構(gòu)設(shè)計風格?》中,探討了一種業(yè)務(wù)架構(gòu)的設(shè)計規(guī)范,以期達到這些目標:用標準約束技術(shù)細節(jié);用技術(shù)工具而非文檔推行標準;持續(xù)重構(gòu)而非造新輪子;重視業(yè)務(wù)建模。但通篇表述較為抽象。本篇將總結(jié)團隊近來的架構(gòu)演進工作,以更具體的技術(shù)細節(jié),詳細闡釋該理念,作為“統(tǒng)一業(yè)務(wù)設(shè)計風格”的實踐篇。文中詳述了多個層面的設(shè)計規(guī)約和基于規(guī)約的搭建方式,并在末尾回答了上一篇的諸多疑問。

二 總覽

上圖以電商產(chǎn)品為例,展示了一套標準框架的各層設(shè)計單元。先簡單了解下概念,下一章節(jié)會詳細解釋各層的設(shè)計規(guī)約和搭建方式:

  • 產(chǎn)品模式層

以產(chǎn)品合約描述完整的功能列表;以簽署人身份來定位產(chǎn)品功能的適用場景;以合約分組來描述一個獨立完備的功能域,分組的集合就是產(chǎn)品功能的范圍和邊界。通過對合約分組進行組裝,可以快速搭建商業(yè)產(chǎn)品。

  • 業(yè)務(wù)模型層

為了減少不同技術(shù)同學(xué)對領(lǐng)域進行建模的風格差異,我們對業(yè)務(wù)模型的使用場景做了諸多約定,串聯(lián)起倉儲管理/業(yè)務(wù)流程/業(yè)務(wù)組件等基礎(chǔ)模塊。所有人更關(guān)注于業(yè)務(wù)在模型上的表達,而大大減少了對實現(xiàn)細節(jié)的關(guān)注。基于對領(lǐng)域的分析,可以快速搭建業(yè)務(wù)模型。

  • 業(yè)務(wù)流程層

用一套標準的業(yè)務(wù)流程框架,描述業(yè)務(wù)模型的完整執(zhí)行流程:業(yè)務(wù)組件是一套高內(nèi)聚的業(yè)務(wù)功能集合,基于組件配置將業(yè)務(wù)模型的信息適配為標準參數(shù),交由基礎(chǔ)設(shè)施執(zhí)行具體功能;流程引擎負責創(chuàng)建和管理流程實例,接收指令來觸發(fā)組件動作的執(zhí)行,并實現(xiàn)狀態(tài)推進/條件跳轉(zhuǎn)和異常處理等分支管控的需求。通過對業(yè)務(wù)組件/基礎(chǔ)設(shè)施的抽象和沉淀,可以快速搭建業(yè)務(wù)流程。

  • 數(shù)據(jù)視圖層

用一套標準的數(shù)據(jù)流機制,來滿足視圖層的定制化需求:數(shù)據(jù)流訂閱器用于采集數(shù)據(jù),物理來源包含區(qū)塊鏈跨鏈數(shù)據(jù)/業(yè)務(wù)DB數(shù)據(jù)/文件系統(tǒng)數(shù)據(jù)/離線任務(wù)數(shù)據(jù)等;數(shù)據(jù)流消費器用來加工原始數(shù)據(jù),生成展示層數(shù)據(jù)/待核對數(shù)據(jù)/數(shù)據(jù)指標等等。訂閱器確保了數(shù)據(jù)來源的穩(wěn)定和低成本的快速接入,消費器則交由技術(shù)同學(xué)自行定制業(yè)務(wù)邏輯。在不干擾領(lǐng)域建模的基礎(chǔ)上,可以快速搭建數(shù)據(jù)視圖。

三 規(guī)約詳解

1 產(chǎn)品模式

產(chǎn)品合約

1)規(guī)約

  • 產(chǎn)品合約以全局視角,描述完整的業(yè)務(wù)模式,包括:服務(wù)的目標客戶,依賴的業(yè)務(wù)領(lǐng)域,輸出的服務(wù)等等
  • 產(chǎn)品合約的內(nèi)容是一份靜態(tài)描述文件,需要由簽署身份列表來界定使用場景

2)實例

以電商產(chǎn)品為例,商家單獨簽署的產(chǎn)品合約被作為商家合約,描述了商品的上架要求;商家+平臺+買家共同簽署的產(chǎn)品合約,則適用于交易下單場景。

3)搭建

  • 新增/修改
    • 低代碼:基于業(yè)務(wù)需求,在產(chǎn)品中心設(shè)計產(chǎn)品模板,明確合約分組和具體內(nèi)容
  • 使用:
    • 接入時編碼,一次性:在業(yè)務(wù)系統(tǒng)內(nèi)編寫對應(yīng)產(chǎn)品合約和簽署身份的模型類,完成和產(chǎn)品中心的對接,包括合約的創(chuàng)建/失效,基于簽署身份的合約查詢等等

合約分組

1)規(guī)約

合約分組以局部視角,描述某個高度內(nèi)聚的業(yè)務(wù)領(lǐng)域所提供的功能和依賴的配置信息,包括:業(yè)務(wù)模型,業(yè)務(wù)服務(wù),業(yè)務(wù)流程,業(yè)務(wù)組件等等

多個合約分組共同組成一個可交付業(yè)務(wù)的產(chǎn)品合約

2)實例

電商產(chǎn)品合約下,商品分組描述了商品上架的流程和配置,下單分組約束了訂單創(chuàng)建的流程和服務(wù)信息,退貨分組則說明了退貨流程和買家能夠享受的客戶服務(wù)。

3)搭建

  • 新增/修改
    • 低代碼:以元數(shù)據(jù)的方式定義一個合約分組,包含模型/流程/配置等等,每一個配置都可以用鍵路徑/配置值類型和限制等描述
  • 使用
    • 硬編碼:在業(yè)務(wù)系統(tǒng)內(nèi)定義合約分組的模型類,完成與產(chǎn)品合約內(nèi)容交互的寫入和讀取,在業(yè)務(wù)代碼處顯式獲取業(yè)務(wù)分組實例
    • 低代碼:搭建合約查詢->分組解析->配置獲取的通用框架(引入緩存避免重復(fù)查詢),業(yè)務(wù)層只需要通過元數(shù)據(jù)描述,就可以獲取對應(yīng)分組內(nèi)的配置信息

2 業(yè)務(wù)領(lǐng)域

模型

1)規(guī)約

業(yè)務(wù)模型描述一個領(lǐng)域內(nèi)的核心業(yè)務(wù)實體,是唯一貫通業(yè)務(wù)流程和業(yè)務(wù)組件的業(yè)務(wù)實例

一個業(yè)務(wù)模型內(nèi)可以關(guān)聯(lián)其他模型,但應(yīng)避免出現(xiàn)循環(huán)依賴

一個完備的業(yè)務(wù)模型描述需要包含:數(shù)據(jù)模型,視圖模型,業(yè)務(wù)模型/數(shù)據(jù)模型/視圖模型的三者轉(zhuǎn)換,業(yè)務(wù)模型倉儲等

2)實例

退貨業(yè)務(wù),基于退貨單推進業(yè)務(wù)流程,各業(yè)務(wù)組件從退貨單獲取必要的業(yè)務(wù)信息,執(zhí)行退貨/退款/通知等業(yè)務(wù)功能;退貨單關(guān)聯(lián)自一個正向訂單,但正向訂單不可反向依賴退貨單;一個退貨單模型對應(yīng)一張主單據(jù)表和多張退貨明細表,倉儲需要負責完成業(yè)務(wù)模型<->數(shù)據(jù)模型的雙向讀寫

3)搭建

  • 硬編碼:編寫業(yè)務(wù)模型(Model)/數(shù)據(jù)模型(DO)/數(shù)據(jù)交互(Mapper)/視圖模型(VO)/轉(zhuǎn)換層(Converter)/倉儲(Repository)等等
  • 低代碼:用元數(shù)據(jù)描述,自動生成DO/VO/Mapper/Converter;基于底座提供的倉儲組件,也可以通過元數(shù)據(jù)描述,自動生成業(yè)務(wù)模型倉儲的實例

服務(wù)

1)規(guī)約

1、業(yè)務(wù)服務(wù)是一套以業(yè)務(wù)領(lǐng)域為單位(interface)作聚合,開放給內(nèi)外所有使用方的最小業(yè)務(wù)功能單元(method)

2、業(yè)務(wù)服務(wù)需要一套定義規(guī)范(annotation/aop等),對每一個功能單元有清晰直觀的元數(shù)據(jù)描述,用以實現(xiàn)服務(wù)發(fā)現(xiàn)/文檔生成/權(quán)限管控/穩(wěn)定性保障等等。元數(shù)據(jù)包括:業(yè)務(wù)域,業(yè)務(wù)動作,讀/寫,錯誤碼范圍,返回值模型等等

3、業(yè)務(wù)服務(wù)的入?yún)?,限制為一個sysParam和一個bizParam,前者為調(diào)用來源/冪等ID/產(chǎn)品碼/租戶ID等系統(tǒng)參數(shù),后者為各業(yè)務(wù)自行定義的模型參數(shù),建議為可全鏈路透傳(rpc->api->flow->component)的POJO

4、業(yè)務(wù)服務(wù)以Result形式返回,錯誤碼盡量控制在元數(shù)據(jù)描述的范圍內(nèi),不泄漏任何exception給調(diào)用方。返回的業(yè)務(wù)信息,建議為POJO或VO

5、業(yè)務(wù)服務(wù)不局限于調(diào)用方的物理來源,只需要在對接層增加簡單的轉(zhuǎn)換邏輯,做授權(quán)管控即可

6、寫服務(wù)的實現(xiàn),需要有事務(wù)管理機制

2)實例

  1. public interface DemoOrderService { 
  2.     /** 
  3.      * 下單申請 
  4.      * @param sysParam sysParam 
  5.      * @param bizParam bizParam 
  6.      * @return result 
  7.      */ 
  8.     @ApiFunction(apiType = ApiType.SUBMIT, funcBiz = "ORDER",funcAction = "APPLY"
  9.             returnType = OrderApplyResponse.class, errorCodeType = CommonErrorCodeEnum.class) 
  10.     CommonResult<OrderApplyResponse> apply(ApiReqSysParam sysParam, OrderApplyInfo bizParam); 

3)搭建

  • 新增/修改
    • 定義-低代碼:基于元數(shù)據(jù)描述,自動生成interface+method+errorcode+POJO等等
    • 實現(xiàn)
    • 硬編碼:簡單需求/不可模板化/無法流程化的業(yè)務(wù)需求,直接編碼
    • 低代碼:對于標準的流程發(fā)起服務(wù)(申請上架/申請下單/申請退貨),用模板實現(xiàn)合約分組加載->流程配置加載->流程初始化(冪等)->流程觸發(fā)->結(jié)果處理;對于標準的流程推進服務(wù)(通知回執(zhí)/調(diào)度推進),用模板實現(xiàn)流程配置加載->流程觸發(fā)->結(jié)果處理等等。隨著更多服務(wù)場景的出現(xiàn),可以有更多模板化的業(yè)務(wù)服務(wù)。
  • 使用
    • 硬編碼:與所有interface的使用一樣,組裝請求->調(diào)用->處理結(jié)果
    • 低代碼:基于元數(shù)據(jù)描述和業(yè)務(wù)配置,將當前業(yè)務(wù)對象/外部參數(shù)映射為服務(wù)入?yún)⒌腜OJO,異常處理模板化,成功返回的結(jié)果以同樣方式映射回業(yè)務(wù)對象或外部響應(yīng)

流程

1)規(guī)約

1、Flow用于描述一個完整的業(yè)務(wù)流程,基于單個業(yè)務(wù)模型,推進一個或多個業(yè)務(wù)子環(huán)節(jié)

2、對于單個業(yè)務(wù)模型的同一類型業(yè)務(wù)流程,可以有多個Flow定義,以滿足不同業(yè)務(wù)模式的定制需求

3、Flow包含遷轉(zhuǎn) (transition) ,組件 (component) 和動作 (action) 三級結(jié)構(gòu),運作原理如下:每次觸發(fā) (operate) 對應(yīng)于組件的一次action,所有action都成功的component會完結(jié),而所有component都成功的transition將會觸發(fā)Flow和業(yè)務(wù)模型的狀態(tài)遷轉(zhuǎn)。

4、Flow的目標是將復(fù)雜流程拆解成多個原子化的業(yè)務(wù)動作,相互解耦

5、Flow需要結(jié)合業(yè)務(wù)服務(wù)/消息/調(diào)度等調(diào)用入口的觸發(fā),才能實現(xiàn)完備的流程推進

6、Flow需要依賴外部調(diào)用方提供事務(wù)管理機制(通常是業(yè)務(wù)服務(wù)),需要依賴業(yè)務(wù)模型倉儲來控制模型的加載和存儲

2)實例

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2.  
  3. <flow id="OrderApply" version="001" desc="標準下單流程"
  4.     <config> 
  5.         <model class="xxx.xxx.Order"/> 
  6.     </config> 
  7.     <init type="INIT" desc="初始化"
  8.         <action operate="INIT.INIT"/> 
  9.     </init> 
  10.     <transitions> 
  11.         <transition from="INIT" to="ITEM_OCCUPIED"
  12.             <component type="ITEM" desc="扣減庫存"
  13.                 <action operate="ITEM.OCCUPY"/> 
  14.             </component> 
  15.         </transition> 
  16.         <transition from="ITEM_OCCUPIED" to="DISCOUNT_OCCUPIED"
  17.             <component type="DISCOUNT" desc="扣減優(yōu)惠"
  18.                 <action operate="DISCOUNT.OCCUPY"/> 
  19.             </component> 
  20.         </transition> 
  21.         <transition from="DISCOUNT_OCCUPIED" to="SUCCESS"
  22.             <component type="NOTIFY" desc="下單成功通知"
  23.                 <action operate="NOTIFY.SELLER"/> 
  24.                 <action operate="NOTIFY.BUYER"/>               
  25.             </component> 
  26.         </transition> 
  27.     </transitions> 
  28. </flow> 

3)搭建

  • 新增/修改
    • 低代碼:Flow自身的運作由底座組件支撐,只需一次性編碼;若需要定義業(yè)務(wù)流程,可基于業(yè)務(wù)組件模板和業(yè)務(wù)模型,動態(tài)生成Flow配置文件;加上版本控制和隔離機制,就可以防止兼容性問題
  • 使用
    • 硬編碼:Flow初始化場景,從當前業(yè)務(wù)領(lǐng)域的合約分組中,獲取需要的Flow配置,初始化流程并推進;Flow推進場景,基于modelId+modelType+operate+request,可以用模版化代碼自動觸發(fā)
    • 低代碼:通過對合約分組中Flow配置的標準化,可以將Flow初始化場景也以模板化的方式實現(xiàn);當一個現(xiàn)有業(yè)務(wù)服務(wù)需要支持新定制的業(yè)務(wù)流程時,只需調(diào)整合約內(nèi)的配置即可

組件

1)規(guī)約

1、業(yè)務(wù)組件是某一類業(yè)務(wù)動作的聚合,面向業(yè)務(wù)功能設(shè)計,不局限于任何一個業(yè)務(wù)模型

2、業(yè)務(wù)組件的業(yè)務(wù)動作,是原子化的最小業(yè)務(wù)單元,粒度暫無強制要求,但以解耦和復(fù)用程度為衡量依據(jù);建議其依賴一個到多個基礎(chǔ)設(shè)施/業(yè)務(wù)服務(wù),以模板化的方式提供標準的業(yè)務(wù)動作實現(xiàn)

3、對于某個業(yè)務(wù)模型,業(yè)務(wù)組件通過開放適配器(詳見【基礎(chǔ)設(shè)施-適配】)的方式支持受控定制,或以完全復(fù)寫的方式實現(xiàn)排他定制(不允許其他業(yè)務(wù)復(fù)用)

4、所有的核心業(yè)務(wù)邏輯,都應(yīng)收歸到業(yè)務(wù)組件層及其以下(無流程的簡單業(yè)務(wù)服務(wù)除外),包括但不限于:參數(shù)校驗,業(yè)務(wù)校驗,重入/冪等控制,業(yè)務(wù)模型變更,合約分組變更,計算規(guī)則,外部服務(wù)交互等等

5、業(yè)務(wù)組件需要一套定義規(guī)范(xml/annotation等),對其支持的業(yè)務(wù)動作和業(yè)務(wù)模型有清晰直觀的元數(shù)據(jù)描述,用以搭建業(yè)務(wù)流程。元數(shù)據(jù)包括:業(yè)務(wù)動作列表和對應(yīng)的觸發(fā)點(operate),支持的業(yè)務(wù)模型列表

2)實例

  • 核身組件定義類
  1. public interface BizModelDiscountComponent<T extends BizModel> extends BizModelComponent<T> { 
  2.  
  3.     /** 
  4.      * 占用優(yōu)惠 
  5.      * @param context 
  6.      */ 
  7.     void occupy(FlowContext context); 
  8.  
  9.     /** 
  10.      * 退回優(yōu)惠 
  11.      * @param context 
  12.      */ 
  13.     void refund(FlowContext context); 
  • 核身組件元數(shù)據(jù)配置
    1. <componentTemplate type="DISCOUNT" desc="優(yōu)惠"
    2.     <interface name="xxx.xxx.BizModelDiscountComponent"/> 
    3.     <bizModelMappings> 
    4.         <bizModelMapping> 
    5.             <bizModel class="xxx.xxx.Order"/> 
    6.             <componentEntry name="orderDiscountComponent"/> 
    7.         </bizModelMapping> 
    8.         <bizModelMapping> 
    9.             <bizModel class="xxx.xxx.RefundOrder"/> 
    10.             <componentEntry name="refundOrderDiscountComponent"/> 
    11.         </bizModelMapping> 
    12.     </bizModelMappings> 
    13.     <triggerMappings> 
    14.         <triggerMapping> 
    15.             <triggerTemplate operatePostfix="OCCUPY"/> 
    16.             <methodEntry name="occupy"/> 
    17.         </triggerMapping> 
    18.         <triggerMapping> 
    19.             <triggerTemplate operatePostfix="REFUND"/> 
    20.             <methodEntry name="refund"/> 
    21.         </triggerMapping> 
    22.     </triggerMappings> 
    23. </componentTemplate> 
  • 核身組件模板化實現(xiàn)

適配器Adapter的解釋,詳見【模型適配】小節(jié)

  1. public abstract class AbstractBizModelDiscountComponent<T extends BizModel> implements BizModelDiscountComponent<T> { 
  2.     @Resource 
  3.     private DiscountApiService discountApiService; 
  4.  
  5.     @Override 
  6.     public void occupy(FlowContext context) { 
  7.         // TODO AdapterConfigInfo根據(jù)context從當前合約中獲取 
  8.         T bizModel = (T) context.getBizModel(); 
  9.         getDiscountAdapter().processOnOccupyResult( 
  10.                 bizModel, 
  11.                 discountApiService.occupy(getDiscountAdapter().toOccupyInfo(bizModel, new AdapterConfigInfo())) 
  12.         ); 
  13.     } 
  14.  
  15.     @Override 
  16.     public void refund(FlowContext context) { 
  17.         // TODO AdapterConfigInfo根據(jù)context從當前合約中獲取 
  18.         T bizModel = (T) context.getBizModel(); 
  19.         getDiscountAdapter().processOnRefundResult( 
  20.                 bizModel, 
  21.                 discountApiService.refund(getDiscountAdapter().toRefundInfo(bizModel, new AdapterConfigInfo())) 
  22.         ); 
  23.     } 
  24.  
  25.     @SuppressWarnings("unchecked"
  26.     protected BizModelToDiscountAdapter<T> getDiscountAdapter(){ 
  27.         return (BizModelToDiscountAdapter<T>) FlowInstanceFactory.instanceBizAdapter( 
  28.                 "DISCOUNT", (Class<? extends BizModel>) TypeUtils.getRealClassOfParameterizedType(this)); 
  29.     } 

3)搭建

  • 新增/修改
    • 硬編碼:全新業(yè)務(wù)組件基本無法低代碼化,需要開發(fā)有足夠的設(shè)計思維和大局觀,權(quán)衡復(fù)用度和成本后實現(xiàn)初版;隨著業(yè)務(wù)發(fā)展,逐步抽象出模板化的業(yè)務(wù)組件實現(xiàn);很多場景下,如果避免不了復(fù)雜的定制邏輯,可以自行以策略/職責鏈/工廠等多種設(shè)計模式落地,這依賴于開發(fā)者的建模能力,不做強制要求
    • 低代碼:已有的業(yè)務(wù)組件應(yīng)用于新業(yè)務(wù)模型的場景,如果已經(jīng)抽象出合約配置+適配器+基礎(chǔ)設(shè)施的標準模板,只需做合約配置即可(通知/核身/存證上鏈等場景適合)
  • 使用
    • 低代碼:在Flow底座中完成業(yè)務(wù)組件的編排/發(fā)現(xiàn)和觸發(fā),一次性編碼;完成Flow配置,即完成業(yè)務(wù)組件的裝配

3 基礎(chǔ)設(shè)施

注:此處的基礎(chǔ)設(shè)施與DDD中的概念有很大差異,請勿混淆

規(guī)約

基礎(chǔ)設(shè)施是一套以高復(fù)用高內(nèi)聚低變化的外部服務(wù)能力為單位(interface)作聚合,開放給業(yè)務(wù)服務(wù)/業(yè)務(wù)組件使用的最小功能單元(method)

基礎(chǔ)設(shè)施可以是對渠道能力的封裝,如外部商家渠道服務(wù)/跨境渠道服務(wù)等;也可以是對通用技術(shù)能力的封裝,如優(yōu)惠服務(wù)/商品服務(wù)/客戶服務(wù)等

基礎(chǔ)設(shè)施和業(yè)務(wù)服務(wù)的差異在于:前者的核心功能通常由外部服務(wù)提供,在當前系統(tǒng)內(nèi)的核心職責是參數(shù)組裝/場景識別/返回解析和異常處理

基礎(chǔ)設(shè)施的定義不依賴于外部服務(wù),入?yún)樽孕卸x的標準POJO,返回值同樣以Result封裝,屏蔽外部服務(wù)的exception和業(yè)務(wù)異常,業(yè)務(wù)返回同樣是標準POJO

實例

  • 基礎(chǔ)設(shè)施-信息通知
  1. public interface NotifyGateway { 
  2.  
  3.     /** 
  4.      * 通知(郵件/短信/站內(nèi)信) 
  5.      * @param notifyInfo 
  6.      * @return 
  7.      */ 
  8.     CommonResult<NotifyResponse> notify(NotifyInfo notifyInfo); 

搭建

  • 新增/修改
    • 硬編碼:基礎(chǔ)設(shè)施的接入通常是一次性的,低代碼的價值不易發(fā)揮
  • 使用
  • 硬編碼:在業(yè)務(wù)服務(wù)/業(yè)務(wù)組件等調(diào)用方代碼中,組裝入?yún)?>調(diào)用->解析返回
  • 低代碼:在業(yè)務(wù)組件中,基于下文將介紹的適配機制,可以實現(xiàn):合約配置+模板化業(yè)務(wù)組件,低代碼復(fù)用現(xiàn)有基礎(chǔ)設(shè)施

4 模型適配

規(guī)約

  • 模型適配用于銜接業(yè)務(wù)模型和基礎(chǔ)設(shè)施/業(yè)務(wù)服務(wù),實現(xiàn)模型->入?yún)⒑头祷?>模型的雙向處理
  • 在模板化的業(yè)務(wù)組件中,適配器和基礎(chǔ)設(shè)施/業(yè)務(wù)服務(wù)的調(diào)用鏈已經(jīng)固化,各業(yè)務(wù)模型的組件實例只需要實現(xiàn)對應(yīng)的適配器,即可完成業(yè)務(wù)定制
  • 適配器通常與產(chǎn)品合約配置結(jié)合,描述業(yè)務(wù)模型->基礎(chǔ)設(shè)施/業(yè)務(wù)服務(wù)入?yún)⒌挠成潢P(guān)系

實例

  • 適配器-業(yè)務(wù)模型->網(wǎng)銀簽名
  1. public abstract class BizModelToDiscountAdapter<U extends BizModel> implements BizModelAdapter<U> { 
  2.     @Override 
  3.     final public String getType(){ 
  4.         return "DISCOUNT"
  5.     } 
  6.     /** 
  7.      * 生成扣減申請 
  8.      * @param bizModel 
  9.      * @return 
  10.      */ 
  11.     abstract public OccupyInfo toOccupyInfo(U bizModel, AdapterConfigInfo configInfo); 
  12.  
  13.     /** 
  14.      * 處理扣減結(jié)果 
  15.      * @param bizModel 
  16.      * @param result 
  17.      */ 
  18.     abstract public void processOnOccupyResult(U bizModel, CommonResult<OccupyResponse> result); 
  19.  
  20.     //... 
  • 訂單模型Order,需要使用優(yōu)惠扣減服務(wù)時,需要實現(xiàn)適配器BizModelToDiscountAdapter:
  1. @BizAdapter 
  2. public class OrderToDiscountAdapter extends BizModelToDiscountAdapter<Order> { 
  3.     @Override 
  4.     public List<ConfigDef> getConfigDefs() { 
  5.         return Lists.newArrayList( 
  6.                 ConfigEnum.DISCOUNT_TYPE, 
  7.                 ConfigEnum.DISCOUNT_TERM 
  8.         ); 
  9.     } 
  10.  
  11.     @Override 
  12.     public OccupyInfo toOccupyInfo(Order bizModel, AdapterConfigInfo configInfo) { 
  13.         // 解析出客戶選擇的優(yōu)惠類型 
  14.         return new OccupyInfo(); 
  15.     } 
  16.  
  17.     @Override 
  18.     public void processOnOccupyResult(Order bizModel, CommonResult<OccupyResponse> result) { 
  19.         // TODO 根據(jù)扣減成功的優(yōu)惠,重新計算訂單金額 
  20.     } 
  21.  
  22.     // ... 

搭建

  • 新增/修改
    • 定義-硬編碼:當業(yè)務(wù)組件和基礎(chǔ)設(shè)施/業(yè)務(wù)服務(wù)出現(xiàn)調(diào)用關(guān)系時首次定義,通常不再變更
    • 實現(xiàn)-低代碼:可以用一套靈活的合約配置描述映射關(guān)系,實現(xiàn)一次編碼后只需配置維護;但是,這既依賴于DSL級別的描述能力,也需要業(yè)務(wù)模型和基礎(chǔ)設(shè)施/業(yè)務(wù)服務(wù)的設(shè)計者,都具備較高的抽象能力,成本較高
  • 使用
    • 硬編碼:當業(yè)務(wù)開發(fā)抽象出可模板化的業(yè)務(wù)組件時,即完成了首次接入;當基礎(chǔ)設(shè)施/業(yè)務(wù)服務(wù)出現(xiàn)新模式時,需要進行適配調(diào)整

四 總結(jié)

啰嗦了這么多,為避免被過度細節(jié)沖淡主題。最后以幾個問題做個小結(jié):

1 業(yè)務(wù)設(shè)計規(guī)范體現(xiàn)在哪里?

架構(gòu)層面,從產(chǎn)品合約->業(yè)務(wù)領(lǐng)域->基礎(chǔ)設(shè)施,我們對應(yīng)用做了模塊拆解,在不同層面設(shè)計了業(yè)務(wù)規(guī)約,約束了各模塊的職責;技術(shù)層面,通過多個底座組件,一定程度上實現(xiàn)了平臺和業(yè)務(wù)定制的隔離,限制了業(yè)務(wù)細節(jié)的無序散布。

2 業(yè)務(wù)設(shè)計只有合適沒有標準,為何要強制規(guī)范?

規(guī)范的目的不是標準本身,本文提出的標準也未必適合所有問題域。想傳達的是,團隊內(nèi)需要有業(yè)務(wù)設(shè)計的某種共識和沉淀,在每次迭代需求和每次項目產(chǎn)出的基礎(chǔ)上,持續(xù)積累持續(xù)重構(gòu)持續(xù)優(yōu)化,這對新人融入/個人成長和團隊協(xié)作都很有幫助。

3 如何快速支撐業(yè)務(wù),研發(fā)效能提升體現(xiàn)在哪里?

需要明確的是,對于全新的業(yè)務(wù)需求,不會帶來明顯的效能提升,甚至?xí)榱藵M足設(shè)計規(guī)范,帶來一定程度的額外成本。但當多人協(xié)作,工作交接,或是現(xiàn)有功能部分可復(fù)用的場景下,會減少很多不必要的溝通和維護成本。舉例來說,當一個業(yè)務(wù)需求出現(xiàn)時,研發(fā)人員需要做如下判斷:

  • 業(yè)務(wù)模型:是否需要新的業(yè)務(wù)模型,是否需要調(diào)整現(xiàn)有模型
  • 業(yè)務(wù)服務(wù):xxxxxxxxxxxx業(yè)務(wù)服務(wù),xxxxxxxxxxxx現(xiàn)有服務(wù)
  • 業(yè)務(wù)流程:xxxxxxxxxxxx業(yè)務(wù)流程,xxxxxxxxxxxx現(xiàn)有流程
  • 業(yè)務(wù)組件:xxxxxxxxxxxx業(yè)務(wù)組件,xxxxxxxxxxxx現(xiàn)有組件
  • 基礎(chǔ)設(shè)施:xxxxxxxxxxxx基礎(chǔ)設(shè)施,xxxxxxxxxxxx現(xiàn)有設(shè)施
  • 產(chǎn)品合約/合約分組:基于上述判斷,評估產(chǎn)品合約和合約分組的組裝

 

帶來的效能提升有這樣幾點:業(yè)務(wù)領(lǐng)域的每個模塊互相解耦,研發(fā)過程并行化,投入人員1+1可以=2;改造范圍更易于定位,資源評估更為準確,進度把控更加清晰;針對頻繁變動且成本過高的模塊,進行針對性的重構(gòu),影響范圍可控;上文中的很多處規(guī)約,都有潛在的低代碼化可能,能進一步提升搭建效率。

 

責任編輯:武曉燕 來源: 51CTO專欄
相關(guān)推薦

2021-10-26 16:09:26

Windows 11操作系統(tǒng)微軟

2011-06-28 16:40:17

Qt Widget 圖片

2024-05-29 07:56:41

2022-03-10 08:31:51

REST接口規(guī)范設(shè)計Restful架構(gòu)

2021-07-12 11:24:00

流利說可觀察性平臺阿里云

2019-09-29 10:23:09

APIJava編程語言

2012-11-27 12:23:28

2024-12-16 08:34:13

2023-10-17 08:15:28

API前后端分離

2024-07-11 07:02:01

2017-08-28 15:00:20

軟件系統(tǒng)架構(gòu)風格

2019-11-20 09:25:03

Visual Stud編程語言

2021-07-29 07:55:20

React實踐代碼

2022-11-28 08:15:14

Go語言代碼

2022-12-05 09:32:29

Go 語言風格規(guī)范

2021-07-08 07:30:13

Webpack 前端Tree shakin

2022-03-04 08:17:53

PageRank網(wǎng)絡(luò)等級

2012-01-17 10:20:25

Web App最佳實踐用戶體驗

2019-11-13 14:00:48

Java架構(gòu)微服務(wù)

2024-03-22 15:09:32

點贊
收藏

51CTO技術(shù)棧公眾號

亚洲综合五月天婷婷丁香| 国产精品扒开腿做爽爽爽a片唱戏| 国产在线观看免费| 久久精品免费观看| 欧美大尺度激情区在线播放| 在线视频 日韩| 日本亚洲欧洲无免费码在线| 亚洲午夜一区二区三区| 日本一区二区三区免费看| 国产丰满果冻videossex| 亚洲视频1区| 久久精品久久久久久| 中文成人无字幕乱码精品区| 欧美大陆国产| 婷婷六月综合亚洲| 伊人久久大香线蕉成人综合网 | 欧美日韩在线不卡| 欧美国产视频一区| 爱久久·www| 成人的网站免费观看| 国产精品视频久久久| 日本中文字幕在线免费观看| 国产高清一区| 亚洲欧美国产精品久久久久久久| 中文在线字幕观看| 成人久久网站| 精品久久久一区| 国产 国语对白 露脸| 99reav在线| 精品人妻久久久久一区二区三区 | 精品自拍偷拍视频| 神马午夜久久| 亚洲精品一区二区三区香蕉| 亚洲第一区第二区第三区| 美女网站在线看| 一区二区激情小说| 正在播放一区二区三区| 国产黄在线播放| 99re这里只有精品视频首页| 97欧洲一区二区精品免费| 免费看污视频的网站| 亚洲美洲欧洲综合国产一区| 欧美激情精品久久久久久大尺度 | 99久久精品国产亚洲精品 | 日本高清在线观看wwwww色| 99国产精品一区| 高清免费日韩| 亚洲av综合色区无码一二三区| 久久精品99国产国产精| 国产精品揄拍500视频| 男操女视频网站| 久久久久一区| 国产精品1234| 成年人视频免费| 水蜜桃久久夜色精品一区的特点| 茄子视频成人在线| 国产成人一级片| 亚洲综合欧美| 日本久久久a级免费| 国产精品视频一区在线观看| 久久久久国产精品一区三寸| 国产成人一区二区三区| 懂色av中文字幕| 蜜桃精品在线观看| 国产在线播放不卡| 国产a级免费视频| 成人综合在线视频| 久久99国产精品| 国产主播福利在线| 亚洲国产高清在线观看视频| 中文字幕在线亚洲三区| 亚洲妇熟xxxx妇色黄| 午夜精品国产更新| 欧美伦理视频在线观看| 婷婷久久免费视频| 欧美一级理论片| 中文字幕一区二区人妻电影丶| 先锋影音国产精品| 中文字幕在线亚洲| 欧美日韩偷拍视频| 亚洲中字在线| 国产欧美婷婷中文| 不卡视频免费在线观看| 91免费看`日韩一区二区| 日韩欧美在线观看强乱免费| bt在线麻豆视频| 午夜精品一区二区三区免费视频| 能在线观看的av网站| 亚洲精品视频导航| 97影院秋霞午夜在线观看| 亚洲一级不卡视频| 亚洲不卡视频在线| 97超碰成人| 亚洲人成伊人成综合网久久久| 长河落日免费高清观看| 亚洲午夜一级| 国产精品久久久久久久av电影| 国产精品一级视频| 久久亚洲一级片| 国产91av视频在线观看| 欧美三级网站| 欧美一区二区三区爱爱| 五月婷婷综合在线观看| 中文av一区| 日本一区二区在线播放| 亚洲成人一级片| 国产婷婷色一区二区三区| 男女激情免费视频| 婷婷激情成人| 国产亚洲精品美女久久久| 久久人人爽人人爽人人| 欧洲金发美女大战黑人| 国产精品一区二区人人爽| 97精品久久久午夜一区二区三区 | 欧美禁忌电影网| 久久精品国产亚洲精品| 中文字幕超碰在线| 国产经典欧美精品| 亚洲欧美日韩精品久久久| 理论不卡电影大全神| 欧美大片拔萝卜| av资源在线免费观看| 鲁大师成人一区二区三区| av观看久久| 老司机精品影院| 欧美性猛交xxxxxxxx| 国产精品无码一区二区三区| 国产在线日韩| 99国产在线观看| 黄色免费在线观看网站| 欧美日韩一区小说| 日本综合在线观看| 久久国产直播| 免费av一区二区三区| 182在线视频观看| 精品国产乱码久久久久久久久| 懂色av粉嫩av蜜臀av一区二区三区| 久久国产免费| 欧美日韩一区二区视频在线观看 | 欧美日韩国产一区中文午夜| 久久久国产精品久久久| 亚洲成人99| 成人性教育视频在线观看| 大片免费播放在线视频| 色综合久久六月婷婷中文字幕| 精品人妻一区二区免费视频| 日韩午夜高潮| 精品国产一区二区三区免费| 超碰97免费在线| 亚洲成人av片| a v视频在线观看| 99久久精品免费看国产 | 久久成人小视频| 精品一区二区免费看| 伊人久久大香线蕉午夜av| 久久亚洲精品人成综合网| 日韩在线中文视频| 国产精品久久久久久无人区| 91露出在线| 亚洲色图视频网| 韩国一区二区在线播放| 欧美日韩一区二区高清| 国产伦理一区二区三区| 在线观看涩涩| 在线观看欧美日韩国产| 亚洲系列第一页| 亚洲男人天堂一区| 中文字幕在线视频播放| 国产精品毛片| 午夜午夜精品一区二区三区文| 久久爱.com| 久青草国产97香蕉在线视频| xxxwww在线观看| 精品久久久久久电影| 91精品人妻一区二区三区蜜桃欧美 | 91国产丝袜播放在线| 91网页版在线| 国产高清视频网站| 国产精品jizz在线观看美国| 国产免费一区二区| 3d性欧美动漫精品xxxx软件| 中文字幕日韩在线视频| 国产男女裸体做爰爽爽| 亚洲一区二区成人在线观看| 免费的av网站| 亚洲视频二区| 夜夜爽99久久国产综合精品女不卡| 成人综合日日夜夜| 97avcom| 免费a级在线播放| 亚洲大胆人体视频| 最新黄色网址在线观看| 亚洲小说欧美激情另类| 人妻av无码一区二区三区| 国产一区二区三区不卡在线观看 | 青春草在线视频| 亚洲九九九在线观看| 国产精品老熟女视频一区二区| 亚州成人在线电影| 三级黄色录像视频| 91丝袜高跟美女视频| 人人爽人人爽av| 久久狠狠婷婷| 黄色大片中文字幕| 婷婷综合网站| 鲁片一区二区三区| 中文字幕av一区二区三区四区| 国产成人久久久精品一区| 日本性爱视频在线观看| 色av中文字幕一区| 日韩美女一级视频| 精品美女一区二区三区| 一级黄色a视频| 91久久精品午夜一区二区| 精品在线免费观看视频| 17c精品麻豆一区二区免费| 亚洲自拍偷拍一区二区| 成人一道本在线| 国产精品久久久久久9999| 日韩国产欧美在线播放| 男女猛烈激情xx00免费视频| 一区二区三区午夜探花| 午夜精品短视频| 国产欧美日韩精品一区二区三区 | 精品国产精品国产偷麻豆| 国产一区二区精品免费| 麻豆久久一区| 96国产粉嫩美女| 全球中文成人在线| 国产美女高潮久久白浆| 日韩欧美另类一区二区| 欧洲s码亚洲m码精品一区| 91黄页在线观看| 欧美国产乱视频| 日本一本在线免费福利| 欧美久久精品午夜青青大伊人| 日本www在线| 色狠狠av一区二区三区香蕉蜜桃| 成年人免费在线视频| 亚洲人精选亚洲人成在线| 男人av在线| 亚洲午夜未删减在线观看| 黄网在线观看| 国产一区二区激情| www.亚洲.com| 中文字幕在线看视频国产欧美| 成人午夜免费在线视频| 色成人综合网| 国产在线观看91精品一区| 国产日本久久| 亚洲综合色激情五月| 欧美黄视频在线观看| 51国偷自产一区二区三区的来源| 国产精品一级在线观看| 97欧洲一区二区精品免费| 国产精品tv| 久久青青草原| 国产一区二区三区不卡视频网站| 日韩一区免费观看| 日韩久久精品网| 国产免费xxx| 合欧美一区二区三区| 国产av天堂无码一区二区三区| 国产一区91| 三年中国国语在线播放免费| 久久精品国产精品青草| 91人妻一区二区三区| 成人黄色一级视频| 超碰97人人干| 中文字幕一区二区三区在线不卡| 久久中文免费视频| 精品福利樱桃av导航| 国产精品无码粉嫩小泬| 91精品国产综合久久久久久| 黄色av小说在线观看| 亚洲精品一区二区三区不| 高清中文字幕一区二区三区| 久久亚洲精品国产亚洲老地址| www在线观看黄色| 国产激情综合五月久久| 欧美成人精品一级| 久久久久久久免费| 国产精品二区不卡| 国产精品无码av在线播放| 日本v片在线高清不卡在线观看| 久久综合桃花网| 久久精品一区二区三区av | 一二三区精品视频| 天堂网视频在线| 91精品国产欧美一区二区18| 四虎在线观看| 久久夜色精品国产亚洲aⅴ| 免费男女羞羞的视频网站在线观看| 日韩av大片免费看| 日韩精品一区国产| 日韩欧美精品一区二区三区经典| 欧美日韩亚洲一区三区| 中文字幕第80页| av色综合久久天堂av综合| jizz日本在线播放| 精品福利一区二区| www.四虎在线观看| 五月天久久网站| 日本国产中文字幕| 久久国产精品99精品国产| 久久人人爽人人爽人人片| 亚洲色图.com| aaaaaa毛片| 亚洲高清久久久久久| 五月天婷婷在线视频| 日本精品性网站在线观看| 国产精品毛片无码| 亚洲欧洲日夜超级视频| 亚洲欧美高清| 国产精品91av| 自拍偷拍国产精品| 亚洲国产精品无码久久久| 精品免费日韩av| 污污视频在线| 91麻豆桃色免费看| 欧美日韩精品在线一区| 看av免费毛片手机播放| 成人av在线网| 久久久久99精品成人片试看| 欧美日韩不卡在线| 国产中文字幕在线看| 日本高清视频精品| 欧洲亚洲一区二区三区| 成人在线播放网址| 国产一区二区三区日韩| 可以免费看av的网址| 欧美亚洲日本国产| 第九色区av在线| 日本久久精品视频| 国产成人调教视频在线观看| www国产精品内射老熟女| av在线综合网| 国产女同在线观看| 亚洲高清免费观看高清完整版| 精灵使的剑舞无删减版在线观看| 91视频免费在线| 68国产成人综合久久精品| 亚洲精品20p| 国产精品精品国产色婷婷| 中文字幕日韩经典| 色av吧综合网| 9999精品| 国产91在线亚洲| av在线免费不卡| 老熟妇仑乱一区二区av| 亚洲一级片在线看| 97成人超碰| 一本一道久久久a久久久精品91| 久久精品国产99| 日韩欧美123区| 精品国产乱码久久久久久老虎 | 热re91久久精品国99热蜜臀| 亚洲欧美校园春色| 国产精品天天av精麻传媒| 中文字幕免费在线观看视频一区| 亚洲一级黄色大片| 久久成人亚洲精品| 福利欧美精品在线| av天堂永久资源网| 国产欧美日韩精品在线| 136福利视频导航| 欧美成人在线免费| 欧美亚洲大陆| 亚洲一区二区三区四区五区xx| 国产精品国产三级国产普通话三级| 国产又黄又大又粗的视频| 欧美高清videos高潮hd| 日韩美脚连裤袜丝袜在线| 乱子伦视频在线看| 一区视频在线播放| 国产91久久久| 国产精品日韩在线播放| 最新欧美人z0oozo0| 中文字幕日韩三级片| 欧美日韩精品一区二区三区四区| 成人日韩欧美| 麻豆精品传媒视频| 精品系列免费在线观看| 国产亚洲精品久久777777| 亚洲日本aⅴ片在线观看香蕉| 亚洲ww精品| av动漫在线观看| 亚洲色图欧美偷拍| 色视频精品视频在线观看| 国产有码在线一区二区视频| 日韩亚洲国产欧美| 国产在线免费看| 亚洲免费视频一区二区| 国产一区二区三区| 蜜臀av午夜一区二区三区| 一区二区三区在线视频观看58 | 久久综合另类图片小说| www.久久91| 精品国产福利在线| 一色桃子av在线|