溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

數據庫分布式架構下為什么要分層

發(fā)布時間:2021-11-16 16:30:54 來源:億速云 閱讀:132 作者:iii 欄目:大數據

這篇文章主要介紹“數據庫分布式架構下為什么要分層”,在日常操作中,相信很多人在數據庫分布式架構下為什么要分層問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”數據庫分布式架構下為什么要分層”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

前言

分布式架構下如果你的服務沒有分層,那么不應該叫分布式架構。有了分層更好的解決服務依賴問題。提高管理效率,開發(fā)效率,運維效率

不分層

當只有兩個服務的時候,好好看的清楚,當有四個服務相互依賴的時候,已經暈了

數據庫分布式架構下為什么要分層

當你有更多服務的時候.....你會?想死,

生產者與消費者分層

分生產者與消費者之后,依賴關系更加明確了,管理起來更加簡單了??聪聢D依賴關系是不是很明確了,模塊直接基本做了依賴解耦了,也方便業(yè)務解耦 數據庫分布式架構下為什么要分層

  1. 生產者與消費者,不是絕對的一一對應的。

    數據庫分布式架構下為什么要分層 這里請問下大家圖中的消費者的模塊為什么分為用戶模塊與登錄日志模塊

  2. 生產者不能調用生產者,消費者也不能調用消費者。意思就是同層之間不允許相互調用,一旦相互調用,等于沒有分層了。 數據庫分布式架構下為什么要分層

  3. 生產者消費者可以有不同人開發(fā)

  4. 分層有利于業(yè)務演進,分離,解耦,

當系統(tǒng)體量大了怎么辦?

曾經經歷過一個大型電商項目,業(yè)務及其復雜,對高性能,高并發(fā)要求極高。實在無法進行拆分了。于是在消費者之上加一層業(yè)務層,解決了上述問題。 數據庫分布式架構下為什么要分層

這個方式是不是有點像中臺的模塊架構。哈哈。

部署目錄規(guī)范
  1. 不部署在/home下的用戶目錄,這樣不利于擴展維護等

  2. 在/(根) 目錄下創(chuàng)建屬于自己的目錄。分別創(chuàng)建消費者,生產者,業(yè)務方三個目錄

  3. 在對應目錄下為服務創(chuàng)建各自的服務名

  4. 在服務目錄創(chuàng)建log目錄用于存放日志,config存放配置文件

.
├── business
│   └── user
│       ├── config
│       └── log
├── consume
│   └── user
│       ├── config
│       └── log
└── producer
    └── user
        ├── config
        └── log

微服務架構項目結構

模塊依賴圖

數據庫分布式架構下為什么要分層

  1. entity

    entiry子模塊里面存放數據庫實體類,TDO。(個人不喜歡什么VO,TDO,DDO,項目就那么大,搞那么復雜干什么細節(jié)請看這種 博客管理與技術之方法(接口)行參與返回請用實體類)

  2. common

    工具模塊,只要有兩個功能。1. entiry里面實體類,TDO之間的轉換。2. 寫一些不通用或者工具庫里面沒有工具方法。當有時間了會把common里面的工具方法,加入到工具庫里面。保證common的單一性

  3. service Interface

    provider子模塊提供的服務接口,由consumers 或者task 調用

  4. provider

    服務提供者,只有被consumere或者task調用之外任何服務都不能調用。

  5. consumers

    服務消費者,可以被business調用或者直接被外部app調用

  6. service-consumers

    consumers子模塊提供的服務接口,business 調用

  7. business

    業(yè)務層

  8. task

    定時任務子模塊,不應該和provider與consumers 耦合。provider與consumers通常會部署多個,而task絕大部分情況只部署一個。如果與provider何consumers 耦合。你可能需要修改每個的配置,如果忘記修改造成啟動多個task或者沒有啟動task里面的任務,會造成致命的問題。

項目結構

數據庫分布式架構下為什么要分層

包路徑應該定義為:

  1. com.dome.user.entity

  2. com.dome.user.common

  3. com.dome.user.service

  4. com.dome.user.provider

  5. com.dome.user.consumers

  6. com.dome.user.service-consumers

  7. com.dome.user.business

  8. com.deme.user.task

業(yè)務架構與基礎組建的關系

數據庫分布式架構下為什么要分層

業(yè)務模塊應該按需加載基礎組建,不寫到業(yè)務模塊里面,也不應該全部依賴。按需加載依賴就行了。

到此,關于“數據庫分布式架構下為什么要分層”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注億速云網站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI