色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

構(gòu)建高可伸縮性的WEB交互式系統(tǒng)(下)

  本文是《構(gòu)建高可伸縮性的WEB交互式系統(tǒng)》系列文章的第三篇,以網(wǎng)易的NEJ框架為例,對(duì)模塊的可伸縮性進(jìn)行分析介紹。

  實(shí)例分析

  NEJ框架根據(jù)前兩篇的描述對(duì)此套架構(gòu)模式做了實(shí)現(xiàn),下面我們用具體實(shí)例講解如何使用NEJ中的模塊調(diào)度系統(tǒng)來拆分一個(gè)復(fù)雜系統(tǒng)、開發(fā)測(cè)試模塊、整合系統(tǒng)等。

  系統(tǒng)分解

  繪制層級(jí)關(guān)系圖

  當(dāng)我們拿到一個(gè)復(fù)雜系統(tǒng)時(shí),根據(jù)交互稿可以繪制出組成系統(tǒng)的模塊的層級(jí)關(guān)系圖,并確定系統(tǒng)對(duì)外可訪問的模塊。

  抽象依賴關(guān)系樹

  從模塊的層級(jí)關(guān)系圖中,我們可以非常方便的抽象出模塊的依賴關(guān)系樹:

  然后,我們將抽象出來的依賴關(guān)系樹根據(jù)UMI規(guī)則進(jìn)行格式化。格式化的主要操作包括:

  • 增加一個(gè)名稱為“/”的根結(jié)點(diǎn)(也可將“m”結(jié)點(diǎn)改為“/”)
  • 每個(gè)結(jié)點(diǎn)增加“/”的子節(jié)點(diǎn)作為默認(rèn)節(jié)點(diǎn)

  至此輸出的依賴關(guān)系樹,具有以下特性:

  • 任何一個(gè)結(jié)點(diǎn)(除根結(jié)點(diǎn)外)到根結(jié)點(diǎn)路徑上的結(jié)點(diǎn)名稱用“/”分隔組合起來即為結(jié)點(diǎn)的UMI值,如list結(jié)點(diǎn)的UMI值為/m/blog/list
  • 任何結(jié)點(diǎn)上的模塊都依賴于他祖先結(jié)點(diǎn)(注冊(cè)有模塊)上的模塊存在,如blog結(jié)點(diǎn)和list結(jié)點(diǎn)均注冊(cè)有模塊,則list結(jié)點(diǎn)上的模塊顯示必須以blog結(jié)點(diǎn)上的模塊的顯示為先決條件

  確定對(duì)外模塊注冊(cè)節(jié)點(diǎn)

  五個(gè)對(duì)外可訪問的模塊:日志、標(biāo)簽、基本資料、個(gè)人經(jīng)歷、權(quán)限設(shè)置,在依賴關(guān)系樹中找到合適的結(jié)點(diǎn)(葉子結(jié)點(diǎn),層級(jí)關(guān)系樹在依賴關(guān)系樹中對(duì)應(yīng)的結(jié)點(diǎn)或“/”結(jié)點(diǎn))來注冊(cè)對(duì)外可訪問的模塊:

  確定布局模塊注冊(cè)節(jié)點(diǎn)

  從可訪問模塊注冊(cè)的結(jié)點(diǎn)往根結(jié)點(diǎn)遍歷,凡碰到兩模塊交叉的結(jié)點(diǎn)即為布局模塊注冊(cè)結(jié)點(diǎn),系統(tǒng)所需的組件相關(guān)的模塊可注冊(cè)到根結(jié)點(diǎn),這樣任何模塊使用的時(shí)候都可以保證這些組件已經(jīng)被載入。

  映射模塊功能

  原則:結(jié)點(diǎn)的公共父結(jié)點(diǎn)實(shí)現(xiàn)結(jié)點(diǎn)上注冊(cè)的模塊的公共功能。

  舉例:blog結(jié)點(diǎn)和setting結(jié)點(diǎn)的公共父結(jié)點(diǎn)為m結(jié)點(diǎn),則我們可以通過切換blog模塊和setting模塊識(shí)別不變的功能即為m模塊實(shí)現(xiàn)的功能,同理其他模塊。

  分解復(fù)雜模塊

  進(jìn)一步分解復(fù)雜模塊,一般需要分解的模塊包括:

  • 可共用模塊,比如日志列表,可以在日志管理頁面呈現(xiàn),也可以在彈層中顯示
  • 邏輯上無必然聯(lián)系的模塊,如日志模塊中日志列表與右側(cè)的按標(biāo)簽查看的標(biāo)簽列表之間沒有必然的聯(lián)系,任何一個(gè)模塊的移除或添加都不會(huì)影響到另外一個(gè)模塊的業(yè)務(wù)邏輯

  至此我們可以得到兩棵系統(tǒng)分解后的依賴關(guān)系樹——對(duì)外模塊依賴關(guān)系樹:

  以及私有模塊依賴關(guān)系樹:

  繪制模塊功能規(guī)范表

  本例中為了說明分解過程,將所有可分解的模塊都做了分解。實(shí)際項(xiàng)目看具體情況,比如這里的/m模塊組合的/?/tab/模塊的功能可以直接在/m模塊中實(shí)現(xiàn),而不需要新建一個(gè)/?/tab/模塊來實(shí)現(xiàn)這個(gè)功能。

  規(guī)范表范例如下所示:

  構(gòu)建目錄

  項(xiàng)目目錄

  項(xiàng)目目錄的構(gòu)建如下圖所示:

  各目錄說明

webroot                    項(xiàng)目前端開發(fā)相關(guān)目錄   |- res                  靜態(tài)資源文件目錄,打包時(shí)可配置使用到該目錄下的靜態(tài)資源帶版本信息   |- src                  前端源碼目錄,最終發(fā)布時(shí)該目錄不會(huì)部署到線上       |- html            |- module      單頁面模塊目錄,系統(tǒng)所有模塊的實(shí)現(xiàn)均在此目錄下            |- app.html    單頁面入口文件

it知識(shí)庫構(gòu)建高可伸縮性的WEB交互式系統(tǒng)(下),轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 舞钢市| 鹤庆县| 土默特右旗| 乌拉特中旗| 阿勒泰市| 兴业县| 赤峰市| 综艺| 岚皋县| 红安县| 富裕县| 榆林市| 江阴市| 西城区| 沭阳县| 五峰| 新安县| 阳西县| 南投市| 突泉县| 漳平市| 庄浪县| 汉沽区| 平陆县| 肃宁县| 唐海县| 北川| 福贡县| 夏邑县| 邵武市| 广平县| 萍乡市| 满城县| 湘乡市| 霸州市| 灌阳县| 贵德县| 鞍山市| 威海市| 鄂温| 金湖县|