在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

電子商務實現業務中臺系統架構思路

數商云 ? 來源:shushangyun ? 2020-04-30 10:25 ? 次閱讀

近年來的數據中臺、業務中臺等系統架構興起,大多數企業在不清楚的中臺背景的情況下就盲目追求,最后只會導致自身平臺丟失原有的優勢框架。在這里,我們來總結下業務架構總原則:大中臺+小前臺框架思維:

1、業務中臺系統采用領域驅動設計(DDD),在其上構建業務能力SAAS,持續不斷進行迭代演進。

2、中臺平臺化定位,進行了業務隔離設計,方便一套系統支撐不同玩法的業務類型和便于定制化擴展。

3、前后端分離,通過服務接入層進行路由適配轉發。

4、天然的分庫分表,消息解耦和分布式緩存設計,支持彈性擴容,以支持業務中臺大數據高并發場景。

數商云為各位分別介紹每個部分。

電商中臺邏輯分布:

電商中臺部分在邏輯上分成了基礎能力和平臺產品兩層,這樣做的好處是,基礎能力層聚焦于穩定收斂的業務模型和基礎服務本身,不會隨著業務和前臺產品的調整發生變化,可以簡單理解為業務模型的DAO。電子商務平臺產品層則專注于通過流程編排類的技術手段,將基礎能力構建成業務的解決方案,解決共性和個性化的問題。我們將以交易的設計為例來說明這個分層理念。

通過對電商交易業務中臺系統的深入分析,可以確定幾乎所有的交易都會涉及下圖中所有的領域(庫存,優惠,價格…),而單看每個域,玩法都是很少變化的,將這些域的基礎能力完全可以沉淀下來形成原子的基礎能力,通過擴展點方式應對將來特殊的場景個性化擴展。

電商業務中臺系統產品層為了應對不同的交易場景(一口價,拍賣,貨到付款,預售…)將原子的基礎能力編排成滿足不同場景的解決方案,以服務的方式透出出去。

業務中臺服務接入層:

業務服務中臺接入層是連接前臺產品和中臺產品層的紐帶,實質就是之前的web應用,不同的是現在前后端分離后,只包含java代碼,使用springBootweb。做參數轉換,路由分發,調用中臺服務,結果封裝。這塊需要做好前后端的交互規范,請求路由映射規范,web工程目錄結構,負載均衡方案,跨越問題和安全問題。

公用基礎組件:

沉淀和抽象出通用獨立的公共基礎組件,這些組件在服務本項目,本團隊的同時,可以開源出去服務更多的人;抽幾個非常重要的組件講一下這么做的目的。

1、數據訪問組件:抽象封裝分庫分表訪問,讀寫分離,主備切換。

2、消息中間件組件:這塊的選擇非常多,就開源的就有activeMQ,RabbitMQ,RocketMQ,Kafka等等,如果不對這塊做封裝,對其上應用做透明化處理,后期做這塊的適配調整就會非常痛苦,特別是這套業務中臺系統會在不同環境中進行部署時。

3、地址庫組件:統一地理地址相關的服務,如果是有拓展國際市場的需求,這塊會顯得的非常重要,不同文化背景的國家,在這塊的差異會非常大,同時國內也涉及3級,4級和5級地址的問題。

云服務&設施容器層:

如果電商系統開發技術團隊不是非常大,又沒有較強的運維技術人員,建議不要購買物理機自己搭建環境,而是直接使用比較成熟的ECS和其他云服務,這樣會節省很多時間成本和一些耗時的運維工作,讓其專注于業務產品的研發,同時使用docker容器部署應用,不僅需要的機器數量比較少而且部署非常便捷高效。

業務中臺的前臺產品:

iosandroidAPP,H5APP,PC站點,微信支付寶小程序都是屬于這層,前臺產品主要是根據業務形態和產品的定位來進行構建。對于電子商務平臺業務來說,主要是指移動APP商城,H5商城,PC商城,小程序商城,這里將以小程序為例來說明:

為了適應小程序,社交電商這樣的熱點,加上有這么優秀的一套電商中臺系統,不搞出點有么有樣的電商前臺產品,不是很沒有道理,為此想破腦袋,我們把電商和送禮結合了起來,做了“禮尚往來”的小程序。

建立穩定和安全保障的業務交易系統

對電商網站這類在線交易系統,流量會隨著運營活動的波動非常大,特別是到了雙11這類大活動的時候,流量的峰值會是平時的幾十~幾百倍,一些接口會放大的更大。核心電子商務平臺系統的指標,流量,接口調用量和rt,以及限流和異常的監控就顯得非常重要了。

在幾年之前,只有BAT幾個大的公司有能力在這方面做的不錯,隨著全民參與的這種大型促銷活動推動技術的進步,以及開源社區和一些大廠將類似方案回饋到開源社區,目前一個小的電商系統開發技術團隊做好這塊也沒有什么難度了。現將總結的企業搭建商城系統用到的框架做個簡單的介紹,更多細節請參考官方文檔。

1、sentinel:是面向分布式服務架構的輕量級流量控制產品,主要以流量為切入點,從流量控制、熔斷降級、系統負載保護等多個維度來幫助您保護服務的穩定性。該電商系統已經過阿里內部雙11多年的驗證,穩定性和可靠性非常不錯,已于最近開源。

2、dubbokeeper:dubbo的官方監控dubbo-monitor-simple在性能上表現非常不好,經常卡死,對比了幾個成熟的框架后,最終確定使用dubbokeeper.dubbokeeper社區版dubboadmin,包括了應用管理,動態配置,統計信息,服務監控和zk信息查看功能。

3、pinpoint:現在基于微服務的架構,一個請求從用戶發起到響應,中間調用鏈路非常長,跨越數十個系統很正常,并且路徑非常多,要定位一個比較耗時的響應,不利用工具,是非常低效的。Pinpoint這樣的工具就是為處理這個問題出現的,Pinpoint的優點是對代碼零侵入,運用JavaAgent字節碼增強技術,追蹤每個請求的完整調用鏈路。

4、Telegraf+influxDB+Grafana:主要用來實現業務數據的實時監控方案,如交易額的不正常波動,訂單量的突然下跌等。Telegraf是收集數據的代理程序,可以根據業務需要添加插件擴展服務,收集到的數據寫入分布式時序數據庫influxDB,再通過grafana可視化的展示出來。

業務中臺系統工程結構:

邏輯結構映射到物理的工程結構,每個邏輯單元對應為一個子工程,如果是用idea開發,就是一個model,當然model里邊會有子model;至于需要打包構建多少個系統其決定性因素是你團隊的規模,如果團隊規模較少,業務中臺系統合并到3-4個左右就足夠了,如果團非常大,一個團隊負責一個業務板塊的,并為其構建多個系統,也是非常正常的,像較大的電商公司,負責商品的就是一個團隊,商品相關的系統就有數10個。以業務交易系統為例,可以將交易的系統合并為一個系統,但在工程的組織結構上是對立的,方便將來的拆分。

用業務中臺化框架來優化電商交易系統優勢

上面介紹了交易業務中臺的設計理念,本篇會詳細的來說為何要用中臺的思想來架構交易系統。要說明白這個問題,我們必須回看業務中臺系統的演化路徑是怎樣隨著業務規模的增長進行變化的。

首先來看初創公司/新業務系統是如何演進的:以基于云計算為基礎的架構模式,大部分的初創的交易系統架構圖如下:

對于一個業務規模很小,業務也比較單一,該架構也是最高效的方式,一到兩個web系統,數個微服務業務系統,一到兩個前臺系統。微服務業務系統將會把會員,商品,類目,店鋪,交易,庫存,物流這些劃分成不同的模塊/包放在一到幾個電商系統,這樣做的好處是非常明顯的,每個人都熟悉所有的代碼,代碼量不大,開發效率高,這在公司剛起步時,是非常接地氣的和最適合的架構。

隨著電子商務平臺公司業務規模和組織的壯大,會基于上面的架構,迭代演進N次,直到電商系統不再是制約公司發展的瓶頸,這期間最重要的架構升級是電子商務系統和數據庫的垂直拆分,異步消息解耦,分布式事務機制,穩定性保障。為了快速說明問題,我們將忽略中間演進版本,直通基于中臺的版本。

中臺系統產生背景

在介紹業務中臺模式之前,先來看看中臺概念的產生背景,中臺研發模式最早產生于芬蘭著名游戲公司supercell.Supercell有員工180人,后被騰訊以100億美金估值收購,其鼎峰時期全球排名top10的游戲,有5個來自supercell,其能快速推出高質量的游戲,其大中臺功不可沒。阿里借鑒了supercell的“大中臺,小前臺”的模式,以解決快速創新試錯的前端業務和日益沉重的淘寶天貓這些核心系統之間的矛盾,以提升研發效率和跨團隊合作。

可以進一步的設想,如果一個電子商務網站公司業務高速發展,特別是互聯網的電商業務模式,出現10倍增速的發展也很正常,這會面臨業務和技術團隊規模變大,電子商務業務也會越來越復雜,就以交易為例,最初就是簡單支撐實物購買場景(消費者付款購買,平臺/商家發貨),隨著用戶和業務的發展,會出現,虛擬商品交易,團購,拼團,拍賣,秒殺,預售等等電商交易業務模式。

最初就是一個電商系統單純的支持一個單一的業務,到了階段二支持三個業務,你還能勉強活著,到了階段三如果還是使用之前的商城系統架構和開發模式,你會陷入泥潭,在階段三必然會出現以下問題:

[if!supportLists]1.[endif]業務之間的電商需求相互影響,修改和測試回歸成本非常高,但還是會發生意想不到的線上問題。

[if!supportLists]2.[endif]由于支撐的商城需求越來越多,沒有人能掌控全局,修改無存下手,開發越來越不敢接需求。

[if!supportLists]3.[endif]多個網站需求并行的開發是場噩夢,團隊經常加班,還是滿足不了業務需求的開發,團隊越來越是瓶頸,經常接到業務方的投訴。

業務中臺化也就是解決這些問題的最佳選擇,將交易域的核心能力和服務,通過梳理抽象沉淀為穩定外化的服務,通過預留的擴展點,來支持個性化擴展。擴展點的開發完全可以由業務系統開發團隊的技術來進行,交易中臺研發將專注于中臺的建設和穩定性,這樣講大大改善開發協作效率,一個業務能不能跑的快,主要依賴于前臺,當然業務中臺的技術團隊需要做好業務隔離和中臺本身的穩定高效進化。

了解交易的一般業務流程,交易的兩個業務流程:

交易訂單創建流程

簡化的逆向退款流程

只舉例2個業務流程,其他的大同小異,對交易業務的分析和梳理,不難發現,交易涉及的業務域可以歸類為以下幾個方面:價格,優惠,庫存,拆單,支付,限購,交付,訂單,超時,售后。

電子商務平臺交易業務中臺架構

通過對電商網站交易業務流程和業務的分析和梳理,采用20/80原則,可以建模抽象出基礎能力層:

交易是很多契約的組合體,基礎能力服務是原子性的,還需要將這些通過流程編排組合成有業務價值的交易產品來統一對外輸出和管理,這就是電子商務交易平臺產品層的職責,解決共性和差異性的問題。

此外電商交易系統需要依賴會員,商品,店鋪,庫存,優惠,支付和物流等這樣的業務服務才能完成一個真正的交易,加上這些我們基本可以確定交易的業務中臺架構圖,如下:

有了整體的全局大圖,接下來我們將會按照如下的框架來詳細介紹每個部分。

業務中臺系統總體設計:

核心業務領域模型,領域模型的設計,還是遵守DDD的原則,這塊做的好壞,關鍵是對這塊業務的理解和未來一段時間的預判,加上抽象歸納。

中臺核心類圖:

從總體設計的角度看,總體的類圖應當是關注業務模型本身,按照之前約定,我們先看BA層的業務模型:

這個類圖,只畫了宏觀和重要的業務域類,其他用來支撐的類圖,將在BA層做展示,目前幫助理解交易這些類圖足夠說明問題,太多反而沒有重點。PA層是對外開放的服務層,按照慣例設計,會有與其DO對應的DTO類,此外考慮到購車更多的是承擔前臺層的功能,BA層不會引入購車,而將其放到了PA層。

PA層的業務對象類圖,除了dto類型外,還增加了消息事件對象,用來將交易的業務變化通過事件消息通知給對其感興趣的訂閱方,要說明的一點是BA層的DO對象,PA層是完全可以使用的。

業務中臺系統核心服務設計:

服務接入層更多的是前后端交互restfulservice的設計,交易的PA層實質上已經做了對外開放的微服務設計(使用dubbo框架),服務接入層的restfulservice幾乎是對微服務進行包裝參數轉換的處理,就沒有必要單獨說明restful

service,直接看PA最重要的幾個服務。

核心鏈路時序設計:

通過最常規的下單購買和支付流程來說明交易的核心調用鏈路是怎么樣的過程,為了簡化說明下面的時序圖簡化了異常鏈路的處理過程和人為減少了依賴的業務中臺系統。進行核心鏈路依賴的設計,是為了在設計階段更好的去評估依賴的合理性,確保交易的性能,安全性和容災處理方面的要求。有了核心調用鏈路圖,你才能在設計階段確定哪些調用是可以減少的,哪些地方可以異步處理,哪些地方可以使用前置緩存,哪些地方需要異步重試,哪些地方不能超時,哪些地方要確保最終一致性,哪些要做冪等處理等等,此外也對下游系統更好的評估自己的流量和響應時間提供了參考依據。lw

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 電子商務系統

    關注

    0

    文章

    13

    瀏覽量

    7031
  • 系統架構
    +關注

    關注

    1

    文章

    69

    瀏覽量

    23543
收藏 人收藏

    評論

    相關推薦

    華為云 Flexus 云服務器 X 實例之 openEuler 系統下部署 OpenCart 開源電子商務平臺

    不僅提供了強大的計算能力和靈活的資源配置,還通過搭載 openEuler 操作系統展現了對開源生態的支持與貢獻。在這樣的高性能基礎設施之上部署 OpenCart 開源電子商務平臺,不僅能夠充分發揮其豐富的功能和工具優勢,還能確保在線商店的穩定運行與高
    的頭像 發表于 12-26 18:15 ?176次閱讀
    華為云 Flexus 云服務器 X 實例之 openEuler <b class='flag-5'>系統</b>下部署 OpenCart 開源<b class='flag-5'>電子商務</b>平臺

    【書籍評測活動NO.53】鴻蒙操作系統設計原理與架構

    知識的“指導老師”。 以華為官方為主導,選擇最權威的參考資料,由鴻蒙開發團隊的專家親自執筆的新書《鴻蒙操作系統設計原理與架構》即將上市啦 ! 對與鴻蒙生態的合作伙伴、基于鴻蒙操作系統
    發表于 12-16 15:10

    深入解析自動駕駛系統的DCU、MCU、MPU、SoC及整車電子架構

    摘要本文探討了自動駕駛的DCU、MCU和MPU在電子電氣架構的作用,比較了分布式與集中式架構的優勢,以及ADAS
    的頭像 發表于 11-20 17:08 ?1253次閱讀
    深入解析自動駕駛<b class='flag-5'>系統</b><b class='flag-5'>中</b>的DCU、MCU、MPU、SoC及整車<b class='flag-5'>電子</b><b class='flag-5'>架構</b>

    傲基科技港交所遞交招股書

    近日,傲基科技正式向港交所遞交了招股書,標志著這家以外貿B2C電子商務運營為核心業務的跨國電子商務公司即將踏上新的發展階段。
    的頭像 發表于 10-09 16:45 ?419次閱讀

    合格評定助力電子商務高質量發展 SGS攜手電商平臺發起行動倡議

    中國認證認可協會在2024年國國際服務貿易交易會上與貿促會商業行業委員會聯合主辦第四屆"合格評定服務貿易便利化"論壇,主題為"合格評定:助力電子商務高質量發展"。
    的頭像 發表于 09-23 09:30 ?322次閱讀

    突破傳統監測模式:業務狀態監控HM的新思路

    一、傳統監控系統的盲區,如何打造業務狀態監控。 在系統架構設計中非常重要的一環是要做數據監控和數據最終一致性,關于一致性的補償,已經由算法部的大佬總結過就不在贅述。這里主要講如何去補償
    的頭像 發表于 08-29 14:36 ?238次閱讀
    突破傳統監測模式:<b class='flag-5'>業務</b>狀態監控HM的新<b class='flag-5'>思路</b>

    工業互聯網數據是什么

    工業互聯網數據是企業數字化轉型過程的一個核心組件,它主要負責數據的匯聚、清洗、整合、存儲、計算和分發。數據在工業互聯網
    的頭像 發表于 07-03 16:34 ?450次閱讀

    積電回應南京工廠獲美國商務部授權

    近日,針對市場上廣泛流傳的積電南京工廠已獲得美國商務部“無限期豁免授權”的傳聞,積電官方正式作出回應。據積電方面透露,美國商務部已核發
    的頭像 發表于 06-21 10:16 ?554次閱讀

    庫克稱中國內地iPhone業務實際上實現增長

    蘋果公司首席執行官蒂姆·庫克(Tim Cook)近日表示,盡管大中華區截至3月份財季的整體收入有所下滑,但中國內地市場的iPhone業務實際上實現了增長,且降幅低于預期。這一積極信號顯示了中國市場對于蘋果產品的強勁需求。
    的頭像 發表于 05-09 09:40 ?326次閱讀

    惠普戰66七代商務輕薄銳龍版電商平臺上線,搭載AMD Ryzen 703

    4 月 30 日,惠普在電子商務平臺發布戰 66 七代銳龍版商務輕薄本,分為 14 英寸和 16 英寸兩款,配備 AMD Ryzen 7035U “Rembrandt”處理器。
    的頭像 發表于 04-30 16:26 ?1053次閱讀

    電力儀表在工廠車間設備電能管理系統的安裝方法

    基于車間用電設備的電能管理系統架構思路及實施方法,從硬件和軟件方面對此方法進行了闡述。對車間舊設備改造以及新的電能管理系統提供一種思路和便捷的方法。
    的頭像 發表于 04-19 10:13 ?600次閱讀
    電力儀表在工廠車間設備電能管理<b class='flag-5'>系統</b>的安裝方法

    打造核心競爭力:高效Web系統數據的設計與實踐

    在數字化的浪潮,數據已經成為企業賴以生存和發展的核心資源。一個高效的Web系統數據,能夠賦予企業在激烈的市場競爭中立于不敗之地的能力。本文將深入探討如何設計和實施一個能夠提升企業
    的頭像 發表于 03-27 17:29 ?773次閱讀

    建設工業數據可以實現哪些功能

    工業數據是一個讓工業數據可持續利用起來的中間層平臺,能夠持續不斷將數據變成重要資產并落地于執行業務實現可視化、可管理、可分析等目標,
    的頭像 發表于 02-01 17:16 ?384次閱讀

    智能網聯汽車電子電氣架構詳解

    汽車電子電氣架構正在由傳統的分布式架構向域集中式和中央集中式演進, 并繼續演進至車路云一體化協同。智能網聯汽車整體軟件架構需要采用 SOA 分層思路
    的頭像 發表于 01-17 09:24 ?2299次閱讀
    智能網聯汽車<b class='flag-5'>電子</b>電氣<b class='flag-5'>架構</b>詳解

    請教:有SPC560B的多任務實系統的例程嗎(freertos)

    請教:有SPC560B的多任務實系統的例程嗎(freertos)
    發表于 01-15 17:04
    主站蜘蛛池模板: 热99精品视频| 国产性色视频| 3344在线观看永久免费| 思思久久好好热精品国产| 久久亚洲精品玖玖玖玖| 亚洲xx网| 天天视频入口| 国产成年网站v片在线观看| 日本高清视频在线www色| 香蕉久久夜色精品国产小说| 亚洲a视频在线| 成人啪啪网站| www.射| 人人搞人人| 99久久99久久精品免费看子伦| 免费黄色小视频| 人人舔| 九九九色| 美女被猛男躁免费视频网站| 色婷婷777| 四虎最新地址| 香港三级理论在线观看网站| 色视频在线看| 韩国在线视频| 韩国三级视频| 午夜视频在线观看一区| 91久久青草精品38国产| 97国产精品人人爽人人做| 天天视频国产免费入口| 国产精品网站在线进入| 狠狠干视频网| 国产精品影视| 午夜影院0606免费| 国产亚洲精品久久午夜| 久久国产免费观看| 精品在线一区二区三区| 欧美性极品xxxxx| 在线观看日本亚洲一区| 亚洲码在线| 久久国产热| 在线成人|