91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

單體架構如何向分布式架構轉型

jf_ro2CN3Fa ? 來源:芋道源碼 ? 作者:芋道源碼 ? 2022-10-20 10:28 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群


背景

我們在聊架構風格之前先明確一個問題,什么是架構?我們?yōu)槭裁匆x擇架構?用來解決哪些問題?

什么是架構

書本定義:“軟件的架構是一種抽象的結構,他由軟件的各個組成部分和這些部分之間的依賴關系構成”。

我的理解是,架構就是根據(jù)業(yè)務選擇合適的技術、中間件,并且按照合適的設計模式對這些模塊,進行組裝來滿足業(yè)務特性的需求。

選擇架構風格的目的

我們選擇架構風格的初衷在于 “三更原則”(自己的理解) :更好地降本提效、更快地發(fā)版上線、更好地維護系統(tǒng)穩(wěn)定性。

任何一個架構風格,都可以實現(xiàn)功能性需求,但是一個好的架構風格能在功能性需求之上,提升非功能性需求。那么你可能會問,什么是非功能性需求?舉例:擴展性、穩(wěn)定性等等。

這里將會以我認知結合踩過的坑,來給大家詳細講一下,我們是如何從單體架構演進到分布式架構。在向分布式單體架構的演進的道路上,又是如何進行的抉擇,以及為什么最后同時選擇了 微服務架構+分布式架構 的原因。接下來就結合一個系統(tǒng)來作為案例,貫穿主線講解。

首先來講一下,最初的單體架構的經(jīng)歷和轉型。

基于 Spring Boot + MyBatis Plus + Vue & Element 實現(xiàn)的后臺管理系統(tǒng) + 用戶小程序,支持 RBAC 動態(tài)權限、多租戶、數(shù)據(jù)權限、工作流、三方登錄、支付、短信、商城等功能

  • 項目地址:https://gitee.com/zhijiantianya/ruoyi-vue-pro
  • 視頻教程:https://doc.iocoder.cn/video/

單體架構

我們在系統(tǒng)創(chuàng)建之初,往往都是集中業(yè)務、單點部署系統(tǒng),所有業(yè)務打一個包,快速上線。滿足了業(yè)務初期的快速發(fā)版上線,而且適合中小公司沒有自己的 PaaS 平臺,應對初期快速迭代的業(yè)務,開發(fā)、迭代、測試、發(fā)布都是非常的便捷。那么單體架構都有什么類型呢?

單體架構類型

單體架構也分為大泥團架構、分層單體架構、模塊化單體架構,他們的區(qū)別是什么呢?

  • 大泥團單體架構 :毫無分層、所有模塊聚焦在一起,相互穿插(除非是你接手需要改造,否則不要創(chuàng)建這樣的架構風格。這種大泥團架構很難拆分,到最后的下場往往都是重新搭建);
  • 分層單體架構 :普遍的選擇。架構進行了簡單的分層,比如傳統(tǒng)的 MVC 三層架構;
  • 模塊化單體架構 :一般是隨著業(yè)務的發(fā)展,由分層單體架構演變而來,特點就是引入了多個業(yè)務模塊并且提供相應的服務能力。

單體架構的優(yōu)缺點

優(yōu)點

  • 應用的開發(fā)很簡單
  • 易于對應用程序大規(guī)模的更改
  • 測試相對簡單、直觀
  • 部署簡單明了
  • 橫向擴展不費吹灰之力

在業(yè)務的初期,單體架構的優(yōu)點,無論從哪個方面來說,都優(yōu)于其他架構風格,但是隨著業(yè)務的增加、耦合,單體架構的缺點也逐漸暴露出來,這個也符合“康威定律”。那么單體架構的“后期”會暴露出哪些問題呢?

缺點

  • 代碼庫膨脹
  • 過度的復雜性會嚇退開發(fā)者
  • 開發(fā)速度慢
  • 從代碼提交到實際部署的周期很長,而且容易出問題
  • 難以擴展
  • 系統(tǒng)的穩(wěn)定性得不到保障
  • 需要長期依賴某個可能過時的技術棧

單體架構的這些缺點,其實影響的還是我上面提到的“三更原則”。經(jīng)過上面的鋪墊,相信大家已經(jīng)對單體架構風格已經(jīng)有了簡單的理解。

光有方法論是不行的,我們得結合項目以及代碼片段來加深理解,做到真正的應用。接下來我就用一個庫存系統(tǒng)來進行串聯(lián)進行講解。先通過這張圖來了解下庫存系統(tǒng)是用來做什么的?

  • 創(chuàng)建之初,1 個服務提供商品庫存維護、庫存查詢、庫存扣減能力。

  • 隨著業(yè)務的發(fā)展,庫存面向多個服務:B 端業(yè)務,平臺內(nèi)部業(yè)務系統(tǒng)、平臺外部中臺。C 端業(yè)務,訂單商品扣減庫存、網(wǎng)關查詢庫存數(shù)量。

06df0526-501e-11ed-a3b6-dac502259ad0.png

單體架構的案例——庫存系統(tǒng)

最初的庫存代碼分層如下:

  • api :對外提供的 Dubbo 服務
  • common :封裝了公共方法
  • dao :封裝了數(shù)據(jù)庫 DHCP 交互
  • domain :實體類
  • inner-api :系統(tǒng)內(nèi)部 API 交互
  • router :廢棄
  • rpc :上下游 RCP 交互
  • service :業(yè)務邏輯層
  • web :Web 服務層
  • worker :任務調(diào)度層
07015446-501e-11ed-a3b6-dac502259ad0.png

在最初很長的一段時間里,我們部署了兩個單體服務。一個是 API 接口來保障上游的庫存查詢以及調(diào)用,另一個是 Web 服務的后臺管理平臺。這兩個單體服務很好的貼合了最初的業(yè)務迭代和發(fā)版速度,但是后來隨著業(yè)務的增加附加調(diào)用量的增加,單體服務的無論是從性能和穩(wěn)定性都出現(xiàn)了較大的波動。

意料之外,情理之中的事故慘案

2015 年 6 月 26 日晚,也是一個促銷活動的前夕,庫存的 Web 管理平臺掛了,原因就是大量庫存導入,服務器的內(nèi)存不足導致機器宕機。商家、運營無法通過導表的方式去維護庫存數(shù)量,在這之前已經(jīng)經(jīng)歷過了多次橫向擴容。還是出現(xiàn)了預料之外的流量和穩(wěn)定性的問題。

0711fe90-501e-11ed-a3b6-dac502259ad0.png

而且在接下來的大促過程當中,庫存的單體服務 API 接口也承受了非常大的壓力。

一方面是上游調(diào)用方有很多,比如 App 端首頁中的門店網(wǎng)關,查詢商品是否有庫存,是否展示。購物車加車,也會查詢商品庫存的數(shù)量,提單則會對庫存數(shù)量進行扣減,乃至后續(xù)的訂單取消同樣也會調(diào)用庫存接口。

另一方面大的 KA 商家通過中臺對接對庫存進行操作,為了盡可能的讓商家門店的庫存和線上平臺的庫存保持一致,減少線上線下庫存不一致導致的超賣、少賣。中臺同步間隔時間都非常短,5 分鐘~10 分鐘就要全量同步一次。后續(xù)隨著入駐的商家增多,這個量級增長得也非常的迅速。于是我們開啟了單體服務向分布式服務演進的大門。

基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 實現(xiàn)的后臺管理系統(tǒng) + 用戶小程序,支持 RBAC 動態(tài)權限、多租戶、數(shù)據(jù)權限、工作流、三方登錄、支付、短信、商城等功能

  • 項目地址:https://gitee.com/zhijiantianya/yudao-cloud
  • 視頻教程:https://doc.iocoder.cn/video/

分布式架構

分布式架構的優(yōu)缺點

優(yōu)點

  • 可用性高
  • 可擴展性高
  • 系統(tǒng)容錯性高
  • 業(yè)務代碼可讀性高
  • 維護簡單

這些優(yōu)點正是我們當時庫存系統(tǒng)欠缺的,尤其是其中的可用性、系統(tǒng)容錯性,是我們系統(tǒng)演進迭代的首要目標。

《分布式架構體系》中描述到,分布式架構的核心理念也是按照(功能、業(yè)務、領域等)對系統(tǒng)進行拆分,通過合理的拆分結構,實現(xiàn)各業(yè)務模塊的解耦,同時通過系統(tǒng)級容錯設計,在廉價硬件基礎設施上構建起高可用、可擴展的開放技術體系。

所以我們庫存系統(tǒng)到底要按照什么進行拆分,功能?業(yè)務?領域?在拆分之前我們一定要明確設計的目標,避免目標方向錯誤帶來的人力、成本資源的浪費。在弄清楚目標之前,我們先了解下分布式架構的缺點,通過了解這些缺點來衡量滿足我們目標的前提下,需要進行哪些方面的取舍,就如 CAP 原則一樣,只能滿足其中的兩個,AP 或者 CP。

2)分布式架構的缺點

  • 服務多,人員對拆分后的業(yè)務模塊理解要花費一些成本
  • 技術棧升級耗費人力
  • 分布式事務的保持
  • 業(yè)務模塊之間的 RPC 交互損耗

庫存系統(tǒng)的特點,高可用、高并發(fā)、強數(shù)據(jù)一致性。接下來我們就來講一下,庫存是如何從單體架構向分布式架構進行的轉型。

單體架構如何向分布式架構轉型

因為庫存面臨的最大的問題是穩(wěn)定性,所以我們首先針對功能進行了拆分。

1)功能拆分

這一步是相對簡單的,我們梳理出庫存面向服務的業(yè)務方進行服務劃分。這部分無需進行太多代碼的改造,一套接口通過變更不同的 group 別名,部署到不同的集群即可。

074d9108-501e-11ed-a3b6-dac502259ad0.png

拆分后,不同的服務應對不同的業(yè)務方,系統(tǒng)錯誤的隔離性好,不會說出現(xiàn)一損俱損的局面,穩(wěn)定性上也有了保障。在解決了穩(wěn)定性的問題后,留給我們了一些喘氣的間隔,可以有時間去進行代碼的優(yōu)化。因為剛才也提到了,我們只是通過分布式的集群部署來解決容錯性的問題,但是代碼還是一套,臃腫的代碼也會拖慢我們的開發(fā)上線速度。那么接下來要進行的就是,對業(yè)務代碼的解耦,這塊也是難度最高的。我們是如何做的呢?

2)業(yè)務拆分

業(yè)務拆分的思路是什么呢?

  • 以業(yè)務本身為導向,充分了解系統(tǒng)業(yè)務模型,劃分業(yè)務邊界;
  • 業(yè)務依賴的范圍,細分功能,盡量減少功能之間的重復依賴;
  • 根據(jù)拆分功能的影響大小進行評估,拆小保大;
  • 拆分的過程中不要修改業(yè)務邏輯,不要進行拆分之外的任何優(yōu)化動作(除非是bug)。

基于上述拆分的思路,庫存系統(tǒng)又是如何劃分的業(yè)務模塊呢?動了哪些代碼?

3)如何劃分業(yè)務模塊

關于業(yè)務劃分,網(wǎng)上有很多方法論,事件風暴法、四色建模法等等,但是萬法不離其宗,那就是圍繞事件。以庫存系統(tǒng)舉例:庫存初始化(門店 + sku 庫存創(chuàng)建)、庫存數(shù)量維護(修改現(xiàn)貨數(shù)量、修改可售狀態(tài))、扣減業(yè)務(購物車扣減、提單扣減、訂單取消扣減)、提醒業(yè)務(缺貨提醒)等。每一個事件都有獨立的鏈路軸,以及時間線可以形成閉環(huán)。

075a0a1e-501e-11ed-a3b6-dac502259ad0.png078961ba-501e-11ed-a3b6-dac502259ad0.png07a6ad1a-501e-11ed-a3b6-dac502259ad0.png

4)如何在原有模塊上拆分

大多數(shù)單體架構都是面向過程的設計,domain 層充斥這個各種 DTO、VO、BO,所以在層與層的數(shù)據(jù)交互過程中,大都是經(jīng)歷了多次的 POJO。另外就是 Service 層充斥著和 DAO 層數(shù)據(jù)交互以及參雜了業(yè)務,而且嚴重違反了依賴倒置原則,整個層變得非常的沉重。這里舉個例子:

  • 同層級間相互引用
  • Service 層包含了太多業(yè)務邏輯,無法保障原子性
07eff7ae-501e-11ed-a3b6-dac502259ad0.png

這里截取部分代碼片段作為案例,來講述下我們在拆分業(yè)務的過程中,需要做一些什么操作。

  • 對 Service 層進行 CQS 的拆分
  • 把業(yè)務邏輯從原有的 Service 層抽離,保障 Service 方法遵循 SRP 原則
  • 新增業(yè)務聚合層(或者向六邊形架構里提到的 adapter 轉接口)來聚合 Service 層的方法
081d378c-501e-11ed-a3b6-dac502259ad0.png

原始代碼

@Service
publicclassSkuMainServiceImplimplementsSkuMainService{
privatestaticfinalorg.slf4j.LoggerLOGGER=LoggerFactory.getLogger(SkuMainServiceImpl.class);

@Resource
privateSkuMainDaoskuMainDao;
@Resource
privateZkConfManagerCenterServicezkConfManagerCenterService;
@Resource
privateProductImagesServiceproductImagesService;//同級互相引用,未遵循依賴倒置
@Resource
privateMqServicemqServiceImpl;

@Value("${system.group.environment}")
privateStringsystemGroupEnvironment;
/**
*問題:service層聚合了太多業(yè)務邏輯倒置上層方法沒辦法統(tǒng)一
*@paramskuMainInfoMQEntity
*@throwsException
*/
publicvoideditorSaveProuct(SkuMainInfoMQEntityskuMainInfoMQEntity)throwsException{
try{
SkuMainBeanskuMainBean=skuMainInfoMQEntity.getSkuMainBean();
if(skuMainBean==null){
thrownewException("修改參數(shù)為空!");
}

SkuMainBeanoriginalSku=this.getSkuMainBeanBySkuId(skuMainBean.getId());
if(originalSku==null){
thrownewException("無效SkuId!");
}

SkuMainBeanskuMainUpdate=updateIsWeightMark(skuMainBean);
SkuMainBeanskuMainPre=this.get(skuMainUpdate.getId());
//系統(tǒng)下架的商品強制下架
if(skuMainPre!=null&&skuMainPre.getSystemFixedStatus()!=null&&skuMainPre.getSystemFixedStatus().equals(SystemFixedStatusEnum.SYSTEM_FIXED_STATUS_DOWN.getCode())){
skuMainUpdate.setFixedStatus(FixedStatusEnum.PRODUCT_DOWN.getCode());
}

booleanflag=skuMainDao.editorProduct(skuMainUpdate);
if(flag){
if(!zkConfManagerCenterService.isDefaultStoreStatisticsScore(skuMainBean.getOrgCode())){
SkuMainBeansaveSkumainBean=this.get(skuMainUpdate.getId());
//防止未查到,把緩存覆蓋
if(saveSkumainBean!=null){
cacheSkuMainBean(saveSkumainBean);
}
//發(fā)送Sku修改MQ
sendSkuModifyMq(SkuModifyOpSourceEnum.MIX_UPDATE_SKU,originalSku,newSkuMainInfoMQEntity(skuMainUpdate));
ProductImagesBeanproductImagesBean=productImagesService.queryImagesBySkuId(skuMainUpdate.getId());
SkuMainInfoCheckMQEntityskuMainInfoCheckMQEntity=newSkuMainInfoCheckMQEntity();
skuMainInfoCheckMQEntity.setSkuMainBean(skuMainUpdate);
skuMainInfoCheckMQEntity.setProductImagesBean(productImagesBean);
mqServiceImpl.sendJosMQ(skuMainInfoCheckMQEntity,MqTypeEnum.RcsKeyWordsCheck);
mqServiceImpl.sendJosMQ(skuMainInfoCheckMQEntity,MqTypeEnum.SenseKeyWordsCheck);
}else{
LOGGER.info("addopenplatformsku,notnotnotsendmq!skuId={}",skuMainBean.getId());
}
}
}catch(Exceptione){
LOGGER.error("修改商品信息失敗.e:",e);
thrownewException(e);
}
}

CQS 和 SRP 的改造,拆解 GOD Classes

Read 服務

082efc4c-501e-11ed-a3b6-dac502259ad0.png

Write 服務

085fe26c-501e-11ed-a3b6-dac502259ad0.png

抽離到業(yè)務層 Business 層后

@Service
publicclassSkuMainBusinessServiceImplimplementsSkuMainBusinessService{
privatestaticfinalorg.slf4j.LoggerLOGGER=LoggerFactory.getLogger(SkuMainBusinessServiceImpl.class);

@Resource
privateZkConfManagerCenterServicezkConfManagerCenterService;
@Resource
privateMqServicemqService;
@Resource
privateSkuMainReadserviceskuMainReadservice;
@Resource
privateSkuMainWriteserviceskuMainWriteservice;

@Value("${system.group.environment}")
privateStringsystemGroupEnvironment;
/**
*問題:service層聚合了太多業(yè)務邏輯倒置上層方法沒辦法統(tǒng)一
*@paramskuMainInfoMQEntity
*@throwsException
*/
publicvoideditorSaveProuct(SkuMainInfoMQEntityskuMainInfoMQEntity)throwsException{
try{
SkuMainBeanskuMainBean=skuMainInfoMQEntity.getSkuMainBean();
if(skuMainBean==null){
thrownewException("修改參數(shù)為空!");
}
SkuMainBeanoriginalSku=skuMainReadservice.getSkuMainBeanBySkuId(skuMainBean.getId());
if(originalSku==null){
thrownewException("無效SkuId!");
}
SkuMainBeanskuMainUpdate=skuMainWriteservice.updateIsWeightMark(skuMainBean);
SkuMainBeanskuMainPre=skuMainReadservice.queryDbById(skuMainUpdate.getId());
//系統(tǒng)下架的商品強制下架
if(skuMainPre!=null&&skuMainPre.getSystemFixedStatus()!=null&&skuMainPre.getSystemFixedStatus().equals(SystemFixedStatusEnum.SYSTEM_FIXED_STATUS_DOWN.getCode())){
skuMainUpdate.setFixedStatus(FixedStatusEnum.PRODUCT_DOWN.getCode());
}
booleanflag=skuMainWriteservice.editorProduct(skuMainUpdate);
if(flag){
if(!zkConfManagerCenterService.isDefaultStoreStatisticsScore(skuMainBean.getOrgCode())){
SkuMainBeansaveSkumainBean=skuMainservice.queryDbById(skuMainUpdate.getId());
//防止未查到,把緩存覆蓋
if(saveSkumainBean!=null){
skuMainWriteservice.cacheSkuMainBean(saveSkumainBean);
}
//發(fā)送Sku修改MQ
skuMainWriteservice.sendSkuModifyMq(SkuModifyOpSourceEnum.MIX_UPDATE_SKU,originalSku,newSkuMainInfoMQEntity(skuMainUpdate));
}else{
LOGGER.info("addopenplatformsku,notnotnotsendmq!skuId={}",skuMainBean.getId());
}
}
}catch(Exceptione){
LOGGER.error("修改商品信息失敗.e:",e);
thrownewException(e);
}
}

構建好的業(yè)務層

087b2a36-501e-11ed-a3b6-dac502259ad0.png

拆分小結

拆分到這里,業(yè)務層的劃分基本就比較清晰了。而且在這個增量整合底層代碼的過程中,面向過程的業(yè)務線也都梳理的比較清晰了,底層方法也都提取到了業(yè)務層收口,通過接口對外提供服務。那么接下來我們要面臨的問題就是,如何對具體的讀寫進行拆分。

基于 CQRS 打造分布式服務

上面我們也提到了,進行了整體功能的拆分,并沒有對具體的讀寫服務的拆分。在面向服務的場景下,功能里也是分讀服務、寫服務。那么我們有什么原則來指導讀寫服務的分離么?那就是 CQRS 的思想:命令職責查詢分離,不單單指代碼,同樣也是適用于服務。

092340fe-501e-11ed-a3b6-dac502259ad0.png

優(yōu)先拆分讀還是優(yōu)先拆分寫

建議從拆分讀開始,因為讀服務相對于寫服務簡單一些,而且更容易提高系統(tǒng)對外服務的穩(wěn)定性,寫服務的流程相對底層改動比較大,測試的周期也會比較長。在前期,動寫服務系統(tǒng)出問題的概率會比較大,所以綜合穩(wěn)定性、擴展性來說,優(yōu)先拆分讀服務是一個比較好的選擇。

CQRS 的思想適合所有業(yè)務場景嗎?

以庫存系統(tǒng)舉例,我們就按照 CQRS 的思想復刻一版,看看會出現(xiàn)什么問題。

  • 每一次修改同步庫存寫入任務表
  • schedule 任務讀取任務表
  • 把任務表的修改數(shù)據(jù)同步到 Read 服務中的 Redis 中

在這個過程中,存在兩個問題:

  • 大數(shù)據(jù)量任務同步的問題:也就是 Event Bus 同步 Redis 的數(shù)據(jù)同步速度問題。

  • 延遲問題:庫存要求實時性非常高,如果因為任務積壓導致的延遲,會讓庫存陷入困境之中。大量的庫存數(shù)量不對導致的超賣、超賣會瞬間擊潰業(yè)務。

094d025e-501e-11ed-a3b6-dac502259ad0.png

所以每一個架構、每一種思想都是要結合業(yè)務去分析。我們可以借鑒 CQRS 的命令查詢職責分離,在面對業(yè)務系統(tǒng)部署的時候,不要死板的遵循固有的模式,要對現(xiàn)有的風格做出一定的取舍。所以,我們在應對庫存業(yè)務的時候,基于 CQRS 的風格創(chuàng)建出了庫存獨有的 CQRS-StockCenter。

CQRS 的活學活用:CQRS-StockCenter

  • business 業(yè)務層寫入命令
  • writeService 服務寫入讀服務 Redis
  • MQ 消息作為異步數(shù)據(jù)補全寫入 MySQL 備份、寫入流水
09921a60-501e-11ed-a3b6-dac502259ad0.png

庫存通過這套設計強依賴了 Redis 來作為庫存查詢、修改的中間件。保障了數(shù)據(jù)的強一致性。庫存在原有的服務上,分離了讀寫,保障了系統(tǒng)的 CQRS 命令職責查詢分離。

0a01606e-501e-11ed-a3b6-dac502259ad0.png

分布式事務

大家都知道事務。簡單來說,事務由一組關聯(lián)操作構成,A->B->C ,如果執(zhí)行到C報錯了,那么要回滾 B->A。

對于本地事務來說,這個相對很簡單,如果你用了事務型數(shù)據(jù)庫比如 MySQL,并且不涉及多個數(shù)據(jù)源的情況下,保障事務的 ACID 非常的容易。但是我們這里要提到的就是分布式事務。

系統(tǒng)拆分后,由于每個服務是一個獨立的模塊,負責一塊業(yè)務,那么在整個業(yè)務軸的流程下,各個服務節(jié)點的跨系統(tǒng)事務回滾成為了一個難題。

業(yè)界也有一些方案,比如 JTA(Java Transaction API 即 Java 事務 API)和 JTS(Java Transaction Service 即 Java 事務服務),為 J2EE 平臺提供了分布式事務服務。

但是,這種需要滿足 XA(兩階段提交)的標準非常的重。而且現(xiàn)在的業(yè)務多樣性,很多數(shù)據(jù)庫比如 MongoDB,并不支持 XA 的標準分布式事務,一些流行的中間件,比如 RabbitMQ 和 Kafka 也不支持分布式事務。

審核編輯 :李倩


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 模塊
    +關注

    關注

    7

    文章

    2837

    瀏覽量

    53281
  • 代碼
    +關注

    關注

    30

    文章

    4967

    瀏覽量

    73948
  • 架構
    +關注

    關注

    1

    文章

    532

    瀏覽量

    26589

原文標題:單體架構服務轉型至分布式的踩坑經(jīng)歷

文章出處:【微信號:芋道源碼,微信公眾號:芋道源碼】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    SST固態(tài)變壓器級聯(lián)架構分布式直流母線電壓均壓問題的對策

    在固態(tài)變壓器(Solid State Transformer, SST)的級聯(lián)架構中(通常為級聯(lián)H橋 CHB + 雙有源橋 DAB 構成的 輸入串聯(lián)輸出并聯(lián) ISOP 結構),高壓側由多個模塊串聯(lián)接入電網(wǎng),每個模塊內(nèi)部都擁有獨立的分布式直流母線(DC-link)。
    的頭像 發(fā)表于 02-24 16:16 ?383次閱讀
    SST固態(tài)變壓器級聯(lián)<b class='flag-5'>架構</b>下<b class='flag-5'>分布式</b>直流母線電壓均壓問題的對策

    意法半導體與AutoCore推出基于以太網(wǎng)的ZCU分布式音頻解決方案

    ???????隨著“軟件定義汽車”(SDV)時代的加速到來,車載電子電氣架構(E/E架構)正經(jīng)歷著從分布式ECU功能域控制(Domain)、再到區(qū)域控制(Zonal)的深刻變革。在這
    的頭像 發(fā)表于 02-01 17:33 ?1508次閱讀
    意法半導體與AutoCore推出基于以太網(wǎng)的ZCU<b class='flag-5'>分布式</b>音頻解決方案

    機載系統(tǒng)智能化的基石:分布式網(wǎng)絡控制系統(tǒng)與容器虛擬化技術的深度融合實踐

    創(chuàng)新的“云-邊-端”分布式智能架構,該架構深度融合了分布式綜合模塊化航電系統(tǒng)、邊緣計算、容器化軟件及確定性網(wǎng)絡等前沿技術。
    的頭像 發(fā)表于 01-27 09:13 ?501次閱讀
    機載系統(tǒng)智能化的基石:<b class='flag-5'>分布式</b>網(wǎng)絡控制系統(tǒng)與容器虛擬化技術的深度融合實踐

    分布式 IO 選型注意事項

    定義? 分布式IO是一種脫離傳統(tǒng)集中式 IO 柜,將輸入 / 輸出模塊分散部署在工業(yè)現(xiàn)場設備附近,通過工業(yè)總線(如 Profinet、EtherNet/IP、Modbus TCP 等)與 PLC、MES 等控制系統(tǒng)實現(xiàn)數(shù)據(jù)交互的工業(yè)控制設備。其核心架構由 “主站 +
    的頭像 發(fā)表于 12-30 14:14 ?290次閱讀
    <b class='flag-5'>分布式</b> IO 選型注意事項

    德州儀器(TI)解讀汽車區(qū)域架構中的 TSN:啟用以太網(wǎng)環(huán)形架構和 AVB 分布式音頻

    德州儀器(TI)解讀汽車區(qū)域架構中的 TSN:啟用以太網(wǎng)環(huán)形架構和 AVB 分布式音頻
    的頭像 發(fā)表于 12-24 18:10 ?1.2w次閱讀
    德州儀器(TI)解讀汽車區(qū)域<b class='flag-5'>架構</b>中的 TSN:啟用以太網(wǎng)環(huán)形<b class='flag-5'>架構</b>和 AVB <b class='flag-5'>分布式</b>音頻

    分布式光伏“四可”裝置:可觀、可測、可控、可調(diào)的技術內(nèi)核全解析

    分布式光伏“可觀、可測、可控、可調(diào)”四可裝置,精準切中并網(wǎng)核心痛點,通過全維度功能構建,成為推動分布式光伏從“被動并網(wǎng)”“主動協(xié)同”轉型的關鍵支撐。
    的頭像 發(fā)表于 11-24 11:20 ?500次閱讀
    <b class='flag-5'>分布式</b>光伏“四可”裝置:可觀、可測、可控、可調(diào)的技術內(nèi)核全解析

    從 “單一控制” 到 “智能可視”:分布式系統(tǒng)與傳統(tǒng)音視頻控制系統(tǒng)的關鍵區(qū)別

    分布式可視化控制系統(tǒng)與傳統(tǒng)的音視頻控制系統(tǒng)的區(qū)別主要體現(xiàn)在以下幾個方面: 1.系統(tǒng)架構分布式可視化控制系統(tǒng)采用分布式架構,將音視頻處理、數(shù)
    的頭像 發(fā)表于 10-21 10:52 ?389次閱讀

    分布式光伏環(huán)境監(jiān)測站的技術架構與應用實踐

    分布式光伏環(huán)境監(jiān)測站的技術架構與應用實踐 柏峰【BF-GFQX】一、系統(tǒng)技術架構解析 分布式光伏環(huán)境監(jiān)測站采用“感知層-傳輸層-應用層”三層架構
    的頭像 發(fā)表于 10-13 10:05 ?575次閱讀
    <b class='flag-5'>分布式</b>光伏環(huán)境監(jiān)測站的技術<b class='flag-5'>架構</b>與應用實踐

    【節(jié)能學院】Acrel-1000DP分布式光伏監(jiān)控系統(tǒng)在奉賢平高食品 4.4MW 分布式光伏中應用

    摘要:在“雙碳”和新型電力系統(tǒng)建設背景下,分布式光伏接入比例不斷提高,對配電網(wǎng)電壓、調(diào)度運行及調(diào)峰等環(huán)節(jié)造成強烈沖擊。本文設計包含平臺層、設備層二層架構體系的分布式光伏管控平臺,以及小容量工商業(yè)
    的頭像 發(fā)表于 08-23 08:04 ?3488次閱讀
    【節(jié)能學院】Acrel-1000DP<b class='flag-5'>分布式</b>光伏監(jiān)控系統(tǒng)在奉賢平高食品 4.4MW <b class='flag-5'>分布式</b>光伏中應用

    宏集分享 | 集中式架構還是分布式架構?SCADA架構選型的新趨勢

    HongraxIIoT在工業(yè)數(shù)字化不斷推進的今天,SCADA系統(tǒng)早已不僅是簡單的數(shù)據(jù)監(jiān)控工具,它正在成為保障企業(yè)運行效率、安全性和業(yè)務連續(xù)性的戰(zhàn)略核心。而“選擇集中式、分布式還是混合式架構?”也正
    的頭像 發(fā)表于 08-08 18:15 ?659次閱讀
    宏集分享 | 集中式<b class='flag-5'>架構</b>還是<b class='flag-5'>分布式</b><b class='flag-5'>架構</b>?SCADA<b class='flag-5'>架構</b>選型的新趨勢

    Ceph分布式存儲系統(tǒng)解析

    在當今數(shù)據(jù)爆炸的時代,企業(yè)對存儲系統(tǒng)的需求日益增長,傳統(tǒng)的集中式存儲已經(jīng)無法滿足大規(guī)模數(shù)據(jù)處理的要求。分布式存儲系統(tǒng)應運而生,而Ceph作為開源分布式存儲系統(tǒng)的佼佼者,以其高可用性、高擴展性和統(tǒng)一存儲架構贏得了眾多企業(yè)的青睞。
    的頭像 發(fā)表于 07-14 11:15 ?994次閱讀

    多節(jié)點并行處理架構

    多節(jié)點并行處理架構(如MPP架構)通過分布式計算和存儲實現(xiàn)高性能數(shù)據(jù)處理,其核心設計及典型應用如下: 一、核心架構特征 非共享架構(Shar
    的頭像 發(fā)表于 06-12 08:18 ?622次閱讀
    多節(jié)點并行處理<b class='flag-5'>架構</b>

    訊維AI分布式系統(tǒng)的十大優(yōu)勢

    在數(shù)字化轉型浪潮中,音視頻技術正從傳統(tǒng)的信號傳輸工具演變?yōu)橹悄芙换サ暮诵妮d體。訊維AI分布式系統(tǒng)通過與AI技術的深度融合,構建了"去中心化架構+AI智能引擎"的創(chuàng)新體系,實現(xiàn)了音視頻信號處理、環(huán)境控制、數(shù)據(jù)安全及用戶體驗的全方位
    的頭像 發(fā)表于 04-15 14:53 ?1300次閱讀

    安科瑞Acrel-1000DP分布式光伏監(jiān)控系統(tǒng)在嘉興亨泰分布式光伏項目中的應用

    摘要 分布式光伏發(fā)電系統(tǒng)其核心特點是發(fā)電設備靠近用電負荷中心,通常安裝在屋頂、建筑立面或閑置空地上,截至2025年,分布式光伏發(fā)電系統(tǒng)在全球和中國范圍內(nèi)取得了顯著發(fā)展,成為能源轉型和可持續(xù)發(fā)展的重要
    的頭像 發(fā)表于 04-10 13:17 ?848次閱讀
    安科瑞Acrel-1000DP<b class='flag-5'>分布式</b>光伏監(jiān)控系統(tǒng)在嘉興亨泰<b class='flag-5'>分布式</b>光伏項目中的應用

    分布式光伏發(fā)運維系統(tǒng)實際應用案例分享

    安科瑞劉鴻鵬 摘?要 分布式光伏發(fā)電系統(tǒng)其核心特點是發(fā)電設備靠近用電負荷中心,通常安裝在屋頂、建筑立面或閑置空地上,截至2025年,分布式光伏發(fā)電系統(tǒng)在全球和中國范圍內(nèi)取得了顯著發(fā)展,成為能源轉型
    的頭像 發(fā)表于 04-09 14:46 ?1247次閱讀
    <b class='flag-5'>分布式</b>光伏發(fā)運維系統(tǒng)實際應用案例分享