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

分層架構演化:從單體的插件化演化所引起的思考

開發 架構
最近,在為 Coco 優化分層架構之時,我陷入了各種決策困難之中。所以我通過不斷地延遲決策,以摸清更適合現有系統的現狀。換個簡單來說,在危險邊緣徘徊,以期待能獲取最大的收益。

 [[387794]]

最近,在為 Coco 優化分層架構之時,我陷入了各種決策困難之中。所以我通過不斷地延遲決策,以摸清更適合現有系統的現狀。換個簡單來說,在危險邊緣徘徊,以期待能獲取最大的收益。

在設計新的架構時,我們總會憑借原先的經驗,并結合業務現狀的需求,并根據未來的需求做出我們的設計。即:

  • 過去的經驗。
  • 現在的需求。
  • 未來的方向。

種種因素的影響之下,它注定了我們無法設計一個滿足所有歷史時期的系統。未來會變成現在,現在會變成過去。

Coco 架構設計:從過去到過去的未來

原先對于 Coca 的各種設計問題,以及 Golang 對于多平臺的支持問題等多方面的因素。迫使 Inherd 開源小組在 Coco 在初始階段,便考慮了為 Coco 設計插件系統。直到最近,我們實現了插件系統之后,發現了原來設計的分層架構已經不滿足現今的需求。

雖然,我已經知道新的分層架構應該如何設計,但是我并不想朝那個方向過去。我走走彎路,再看看是否存在一些更有意思的設計。

原始形態:單體架構

在設計初期,我在 Coco 中引入了類似于 Clean Architecture 的分層架構設計(不包含 Cargo 模塊):

  • app,對應于用例(usecases)。
  • bin,對應于 controller。在 Rust 的構建系統中,bin 目錄的會被構建出可執行文件
  • infrastructure,對應于 基礎設施,如調用 Git 的接口、訪問文件系統等。
  • domain,即業務實體、領域模式,包含了系統的業務設計。

在 domain 目錄下,根據了我們的四大基本業務,進行了二次劃分 :

  • cloc
  • git
  • framework
  • architecture
  • ……

盡管,我一直在說我采用的是類似于 Clean Architecture 的分層架構。但是實際上,并沒有采用其中一些重要的設計,比如說通過依賴反轉來控制流向的問題。從個人的角度來看:

  1. 它帶來一定的架構復雜度,需要不斷地傳遞相關的架構知識,能否在開源項目中推廣,有待商榷。
  2. 后續可以通過重構來轉換。我并非非常資深的架構專家,所以以學習為出發點更方便。

作為一個單體應用,這個分層結構湊合著:

  1. 不算太復雜,還能讓開發人員知道哪的代碼往哪里放。
  2. 可以按需演化為 Clean Architecture。
  3. 模塊可以進一步按業務拆分。

故事的開始還是蠻美好的。

復用形態之模塊化

為了在多個不同的系統/應用之間(即 Coco 項目的代碼提供給其它應用)復用代碼 ,系統中產出一些獨立的模塊,如 psa、framework 等等。這也是一個非常常見的模塊化的場景。模塊化在不同的語言里都有一定的相似之處。

譬如:在使用方式上存在本地使用和遠程發布兩種模式。在本地使用時,無需關注語義化版本等一系列的事項,只需關注于代碼本身。一旦時機成熟,也就可以進化為可遠程發布的模塊。

從單體中出現模塊化的一種典型形式便是,在代碼庫中以與源碼同級的目錄呈現。如下:

  1. ├── framework 
  2. ├── psa 
  3. ├── src 
  4. │   ├── app 
  5. │   ├── bin 
  6. │   ├── domain 
  7. │   ├── infrastructure 
  8. │   └── lib.rs 

這里的 framework 和 psa 便是獨立的模塊,一旦其與其它模塊的依賴關系解耦開來,那么它就可以作為獨立的應用發布。

復制 over 復用

順便提一句,對于模塊化的代碼復用來說,如果代碼量較少,那么可以嘗試復制一份代碼,而不是復用做代碼。這樣一來,我們可以通過此來解耦依賴。

插件化的架構演變

同時,為了靈活地擴展系統的功能,我們設計了插件系統。(事實上,更多地從意圖上,我們只是為了減少包體積大小,這樣可以方便地從 GitHub 下載)

于是乎,我們創建了獨立的 plugins 目錄,并在其中創建了對應的模塊,如下的 coco_xxxx 即是插件。同時,我們使用了 plugin_manager 來作為插件的管理器(事實上,后面證明了,這個 manager 不應該獨立作為一個模塊存在):

  1. ├── framework 
  2. ├── plugin_manager 
  3. ├── plugins 
  4. │   ├── coco_container 
  5. │   ├── coco_pipeline 
  6. │   ├── coco_struct 
  7. │   └── coco_swagger 
  8. ├── psa 
  9. ├── src 
  10. │   ├── app 
  11. │   ├── bin 
  12. │   ├── domain 
  13. │   ├── infrastructure 
  14. │   └── lib.rs 

從設計和演進的角度來看,問題并不多,也可以使用。

演進:未來的未來

好了,由于經驗上的不足,我們就面臨了之前沒考慮到的問題。

提取核心模型

從設計思路上來看,我們本應該在原先的架構模型中,提供一個 core 模塊。而在這個 core 模塊里呢,則用于提供一些核心的代碼給插件和應用。

所以,很快地我們就創建了一個 core_model 出來了。我的本義也就只是提供一個核心模型。我不想像一些插件化項目中,在 core 中提供大量非核心的代碼。

只是呢,隨著第一個模型復用需求的出現,很快地就有了第二部分、第三部分。

再次抉擇:基礎設施層的改造

而插件之間除了模型的復用,還會有基礎設施的復用。而這些代碼,我又不想放到 core 里,所以就又需要抽取中一個 infra 的模塊,用來共享基礎設施的代碼。那么問題來了,我們應該如何選擇?

  1. 將原有的 infrastructure 提取到主目錄下,作為單獨的模塊存在。
  2. 雙層infrastructure,即只提取共用的代碼,到主目錄下,作為獨立的模塊。

從架構設計的思想來看,我是支持雙層基礎設施的存在。過多的無意識地復制這些公共代碼,會導致這個包大小的進一步膨脹。一個典型的例子,就是我們在一個被稱為 common 包的 jar 包里,看到一個 common 子包下,還有 common 目錄的存在,即 xxx-common.common.common。

小結:架構的持續演化

故事就到這里了。哪怕一個再小的項目,它的架構模式也會隨著系統的開發,不斷地演化。如果不加以控制,那么系統可能會推動控制。而演進本身呢,也不會是一帆風順的。

不過,我在思考一個新的東西,關于『分層架構適應度函數』。

Yiki:分層架構適應度函數

無論是在 Coco 還是在 Coca 里,我們都在嘗試對系統的分層進行一個評級。而這個評級的其中一個依據是通過依賴關系,來確認各個模塊之間的引用關系,從而判斷系統的分層架構是否是符合需求的。

通過解析模塊之間的引用關系,可以幫效地幫助我們厘清系統模塊之間的合理度。

本文轉載自微信公眾號「phodal」,可以通過以下二維碼關注。轉載本文請聯系phodal公眾號。

 

責任編輯:武曉燕 來源: phodal
相關推薦

2022-12-15 17:15:42

數據庫NoSQL

2016-04-21 10:10:31

Java應用架構

2023-07-10 18:38:53

2014-09-26 09:53:41

系統架構架構架構演變

2015-09-23 14:14:47

LinkedIn架構解析

2014-10-31 09:48:36

Go語言

2022-11-29 11:21:20

單體分層應用架構

2024-08-23 16:04:45

2011-11-16 09:00:39

編程語言

2024-09-24 18:48:43

2017-10-27 16:40:49

Web網站搭建架構演化圖

2010-02-24 17:01:49

2023-11-01 11:38:44

嵌入式MVC

2012-11-20 10:04:46

Winform開發

2017-11-09 15:38:26

OpenRTB 3.0演化

2009-06-10 18:08:14

2017-04-11 15:43:39

JavaScript模塊演化

2015-06-24 15:30:46

2009-07-22 14:53:45

ibmdwIT架構

2012-03-07 11:25:58

編程語言
點贊
收藏

51CTO技術棧公眾號

日本在线观看一区| 欧美有码在线观看视频| 激情小说欧美色图| av成人 com a| 国产色91在线| 亚洲一区亚洲二区| 欧美bbbbbbbbbbbb精品| 日韩dvd碟片| 精品成人私密视频| 日韩大片一区二区| 爱情岛论坛亚洲品质自拍视频网站| 91麻豆国产香蕉久久精品| 成人福利网站在线观看| 日本少妇在线观看| 大片网站久久| 亚洲经典中文字幕| 国产性生活一级片| 网友自拍亚洲| 亚洲国产精品久久不卡毛片| 日韩欧美精品久久| 天天躁日日躁狠狠躁伊人| 另类欧美日韩国产在线| 91成人在线观看国产| 亚洲少妇xxx| 亚洲宅男一区| 亚洲精品一区二区三区99| 国产成人在线综合| 欧美黄色三级| 欧美日韩国产一区在线| 桥本有菜av在线| 精彩国产在线| 97久久精品人人澡人人爽| 亚洲综合成人婷婷小说| www.五月婷婷.com| 国产精品夜夜夜| 欧美极品在线视频| 午夜精品福利在线视频| 日产精品一区二区| 亚洲一区二区国产| 熟女高潮一区二区三区| 日本午夜精品| 亚洲国产日韩欧美综合久久| 91精品人妻一区二区三区蜜桃2| 成人涩涩视频| 91久久久免费一区二区| 妺妺窝人体色www在线小说| 欧美大胆的人体xxxx| 亚洲码国产岛国毛片在线| 一区二区三区四区在线视频| 黄色电影免费在线看| 久久午夜色播影院免费高清| 精品免费二区三区三区高中清不卡| 不卡的日韩av| 国产成人精品亚洲777人妖| 成人免费视频网| 国产精品嫩草影院精东| 国模无码大尺度一区二区三区| 国产美女久久久| 中文字幕欧美在线观看| 蜜桃一区二区三区四区| 国产精品久久久久久久久久免费| 亚洲大尺度在线观看| 丝袜美腿亚洲一区二区图片| 欧美在线亚洲一区| 精品国产xxx| 三级亚洲高清视频| 国产欧洲精品视频| 99久久精品国产一区色| 国产盗摄视频一区二区三区| 91麻豆精品秘密入口| 亚洲精品无遮挡| caoporn国产精品| 欧美激情专区| 99中文字幕一区| 亚洲人一二三区| 亚洲小视频在线播放| 欧美四级在线| 粉嫩老牛aⅴ一区二区三区| 无码人妻丰满熟妇区毛片| 99riav视频一区二区| 91麻豆精品国产91久久久使用方法| 亚洲精品性视频| 在线观看视频一区二区三区| 日韩精品在线第一页| 国产探花视频在线播放| 婷婷六月综合| 欧美激情综合色综合啪啪五月| 韩国av免费观看| 日本视频一区二区| 91久久精品国产91久久性色tv | 午夜久久久久| 午夜精品三级视频福利| 中文字幕天堂在线| 国产大陆精品国产| 欧美日韩精品免费观看| 久久日韩视频| 欧美日韩精品二区| 污污网站免费观看| 久久影院资源站| 在线日韩中文字幕| 久久婷婷一区二区| 日韩电影免费在线| 成人在线视频电影| 在线观看的av| 亚欧色一区w666天堂| 手机视频在线观看| 免费成人蒂法| 久久国产精品免费视频 | 亚洲欧洲视频| 国产精品网红直播| 五月激情丁香婷婷| 成人免费视频在线观看| 男人的天堂99| 亚洲精品一区二区三区在线| 亚洲色图偷窥自拍| 日韩精品视频播放| 国产一区二区在线观看视频| 日韩三级在线播放| 激情黄产视频在线免费观看| 91精品国产综合久久久久久久久久| 亚洲av无码一区二区二三区| 亚洲欧美在线专区| 国产美女被下药99| 国产网站在线播放| 欧美日韩在线观看视频| 中文字幕在线国产| 香蕉久久网站| 国产精品自拍网| 电影在线高清| 黑人巨大精品欧美一区二区三区 | chinese国产精品| 国产精品一卡二| 资源网第一页久久久| 国产精品久久久久av电视剧| 亚洲精品福利视频| 国产在线观看免费av| 国产精品99久| 日本黄xxxxxxxxx100| 台湾天天综合人成在线| 中文字幕国产亚洲| 免费污污视频在线观看| 91麻豆福利精品推荐| 久久久性生活视频| 成人av资源网址| 久久久久国产视频| 亚洲av无码乱码国产精品久久| 亚洲男人天堂一区| 捷克做爰xxxⅹ性视频| 91精品亚洲| 91久久精品国产| 高潮毛片在线观看| 51久久夜色精品国产麻豆| 91香蕉国产视频| 久久99精品国产.久久久久久| 亚洲免费视频一区| 欧美韩国日本| 免费成人高清视频| www.av导航| 婷婷综合在线观看| 少妇大叫太粗太大爽一区二区| 亚洲伦理一区| 日韩国产在线一区| 婷婷久久综合九色综合99蜜桃| 日韩在线精品视频| 99产精品成人啪免费网站| 亚洲精品videosex极品| 风韵丰满熟妇啪啪区老熟熟女| 在线成人国产| 欧美午夜视频在线| 日日夜夜精品| 欧美日韩国产成人在线| 天天操天天插天天射| 色94色欧美sute亚洲线路二 | 亚洲av无码国产综合专区| 亚洲高清视频在线| 国产交换配乱淫视频免费| 奇米精品一区二区三区在线观看 | 国产原创在线观看| 日韩欧美在线123| 日本少妇在线观看| 国产精品网站在线播放| 手机在线免费毛片| 日韩一级网站| 杨幂一区欧美专区| 亚洲综合网站| 国产91色在线|免| 国产欧美久久久久久久久| 亚洲精品一区在线观看| 免费一级a毛片| 亚洲欧美激情插| 亚洲欧美色图视频| 久久99深爱久久99精品| 亚洲精品无码国产| 欧美日韩伦理| 国产精品国产精品国产专区蜜臀ah| videos性欧美另类高清| 日韩在线不卡视频| 天堂在线观看免费视频| 欧美日韩mp4| 日产亚洲一区二区三区| 国产精品久久久久久户外露出 | 91亚洲视频在线观看| 亚洲国产视频直播| 国产亚洲精品精品精品| 成人高清伦理免费影院在线观看| aaaaaa亚洲| 国自产拍偷拍福利精品免费一| 日韩欧美三级一区二区| 国产精品白丝av嫩草影院| 国产热re99久久6国产精品| www.色在线| 久久精品影视伊人网| 青草久久伊人| 亚洲а∨天堂久久精品喷水| 一级黄色片在线播放| 色综合久久中文字幕| 久久国产精品波多野结衣| 亚洲欧洲精品一区二区精品久久久| 一起草在线视频| 国产成a人亚洲| 亚洲免费成人在线视频| 日韩一区精品字幕| 国产妇女馒头高清泬20p多| 91精品电影| 无码免费一区二区三区免费播放| 香蕉久久精品| 精品国产乱码久久久久软件| 亚洲精品一区二区三区在线| 91精品视频播放| 久久电影天堂| 国产精品日韩专区| 久久青青视频| 清纯唯美日韩制服另类| 麻豆mv在线看| 久久久噜噜噜久久久| 欧洲黄色一区| 欧美激情视频网| 欧美hdxxxxx| 国产黄色激情视频| 松下纱荣子在线观看| 欧美床上激情在线观看| 在线日本视频| 中文一区二区视频| 国产鲁鲁视频在线观看免费| 亚洲欧美日韩在线高清直播| 天天操天天操天天| 亚洲国产精品免费| 天天操天天射天天| 亚洲国产日韩欧美在线图片| 成人午夜精品福利免费| 欧美刺激脚交jootjob| 国产黄色大片网站| 欧美变态tickle挠乳网站| 亚洲高清在线观看视频| 精品国精品国产| 国产综合在线播放| 亚洲国产精彩中文乱码av| 天天干天天插天天操| 日韩精品一二三四区| 国产私人尤物无码不卡| 噜噜噜狠狠夜夜躁精品仙踪林| 精品美女在线观看| 亚洲第一视频在线| 亚洲成人网在线观看| 手机av在线免费观看| 日韩久久精品电影| 国产www.大片在线| 精品国偷自产在线视频| v片在线观看| 97国产精品免费视频| 欧美一级大片| 国产精品中文字幕久久久| 日日夜夜亚洲| 国产精品久久亚洲7777| 亚洲最好看的视频| 亚洲一区二区精品在线观看| 综合国产在线| 黄色成人在线看| 日韩电影在线观看一区| 一级片免费在线观看视频| 成人中文字幕合集| 国产ts丝袜人妖系列视频| 国产目拍亚洲精品99久久精品| 精品国产大片大片大片| 一区二区三区高清在线| 可以在线观看av的网站| 欧美年轻男男videosbes| 国产丰满果冻videossex| 亚洲精品狠狠操| 日本蜜桃在线观看| 97国产真实伦对白精彩视频8| japanese23hdxxxx日韩 | 欧美日韩亚洲国产| 91日韩在线播放| 日韩av三区| 三年中文高清在线观看第6集| 亚洲国产精品第一区二区| 久久久久国产精品熟女影院| 国产不卡视频在线播放| 免费人成又黄又爽又色| 亚洲线精品一区二区三区 | 欧美精品高清视频| 天天操天天插天天射| 久久九九亚洲综合| 亚洲承认视频| 国产一区在线观| 亚洲精品久久| 日本熟妇人妻中出| 99麻豆久久久国产精品免费 | 日韩免费久久| 欧美亚洲精品一区二区| 国内精品伊人久久久久av影院| 全黄一级裸体片| 亚洲一区欧美一区| 国产精品久久久久久久久久久久久久久久久久 | 国产精品x8x8一区二区| 一区二区三区四区国产| 免费看亚洲片| 少妇熟女视频一区二区三区 | 亚洲日本精品国产第一区| 国产精品久久久免费| 精产国品一区二区三区| 国产精品久久久久久久久果冻传媒 | 欧美日韩国产区| 黄色美女一级片| 欧美成人亚洲成人| 久久福利在线| 性欧美精品一区二区三区在线播放| 99在线观看免费视频精品观看| 九九九久久久久久久| 欧美国产97人人爽人人喊| 日本中文字幕在线| 日韩电影大片中文字幕| bl视频在线免费观看| 91影院未满十八岁禁止入内| 国产精品久久久久蜜臀| xxww在线观看| 欧美激情中文字幕| 波多野结衣爱爱| 亚洲视频综合网| 香蕉视频亚洲一级| 蜜桃视频在线观看91| 亚洲人成久久| 国产女人18毛片水真多18 | 在线免费观看av网址| 亚洲欧美第一页| 亚洲一区资源| 欧美亚洲精品日韩| 石原莉奈一区二区三区在线观看| 日本xxx在线播放| 欧美性xxxx极品hd欧美风情| 四虎精品在永久在线观看| 69视频在线播放| 小说区图片区色综合区| 国产精品99久久免费黑人人妻| 国产视频在线观看一区二区三区 | 欧美精品自拍偷拍| 国产精品va在线观看视色| 91美女高潮出水| 欧美精品1区| 69亚洲乱人伦| 欧美日韩亚洲精品内裤| 激情小视频在线| 国产精品偷伦一区二区 | 亚洲国产精品激情在线观看| 午夜一级黄色片| 日韩中文字幕免费视频| 精品视频成人| 国产日韩av网站| 久久精品这里都是精品| 97人妻精品一区二区三区动漫| 欧美成人在线影院| 人人网欧美视频| 色乱码一区二区三区在线| 亚洲欧美一区二区三区久本道91| 99久久一区二区| 91禁外国网站| 不卡视频在线| 欧美69精品久久久久久不卡| 五月激情综合婷婷| 成人在线免费电影| 亚洲最大福利网| 久久激情综合| 国产精品免费人成网站酒店 | xfplay5566色资源网站| 一本久久综合亚洲鲁鲁五月天| 日本三级视频在线播放| 国产精品久久久久久久天堂第1集 国产精品久久久久久久免费大片 国产精品久久久久久久久婷婷 | 91露出在线| 成人免费看片网址| 石原莉奈一区二区三区在线观看| 精品国产视频一区二区三区| 亚洲精品色婷婷福利天堂| 欧美jizz18| 69堂免费视频| 亚洲蜜臀av乱码久久精品| 韩日视频在线| 国产高清一区视频| 久久国产日韩欧美精品| 亚洲另类欧美日韩|