王慶友 2003年畢業(yè)于浙江大學(xué),計算機(jī)碩士。前1號店首席架構(gòu)師,先后就職于ebay、騰訊、1號店等大型互聯(lián)網(wǎng)公司。精通電商業(yè)務(wù),擅長復(fù)雜系統(tǒng)業(yè)務(wù)建模和架構(gòu)分析,尤其在大規(guī)模分布式系統(tǒng)的
SOA/微服務(wù)改造方面有很深入的理論和實踐。
王慶友
APP服務(wù)端架構(gòu)變遷及發(fā)展歷史
據(jù)王慶友老師介紹,APP是最近3-5年興起的,其服務(wù)端架構(gòu)大致經(jīng)歷了三個階段:
1. APP剛剛誕生時,其功能非常簡單,無線team負(fù)責(zé)服務(wù)端建設(shè),通過直接訪問各個業(yè)務(wù)系統(tǒng)庫表數(shù)據(jù)或調(diào)用接口,簡單封裝后,提供給APP使用。
2. 隨著APP的功能逐漸豐富,APP服務(wù)端架構(gòu)開始全面拷貝web端的功能,服務(wù)端分散化,由各個業(yè)務(wù)系統(tǒng)直接對外提供。
3. 之后,APP針對無線的特點(diǎn)獨(dú)立發(fā)展,由獨(dú)立的網(wǎng)關(guān)提供服務(wù)端服務(wù),無線team提供網(wǎng)關(guān)基礎(chǔ)設(shè)施和系統(tǒng)級功能,業(yè)務(wù)系統(tǒng)team提供業(yè)務(wù)功能,兩者無縫銜接,統(tǒng)分結(jié)合,支持APP高效擴(kuò)展。
如何分析APP系統(tǒng)級功能需求和結(jié)構(gòu)?
APP一般需要通信、協(xié)議數(shù)據(jù)封裝、信息上報(性能監(jiān)控和行為監(jiān)控),本地數(shù)據(jù)存儲,Native模塊和H5通信等功能。在結(jié)構(gòu)上,通信和協(xié)議數(shù)據(jù)封裝屬于底層,對業(yè)務(wù)系統(tǒng)透明,其它屬于公共模塊,業(yè)務(wù)模塊可以直接調(diào)用。
何為架構(gòu)的本質(zhì)?
一個軟件系統(tǒng)隨著功能越來越多,調(diào)用量急劇增長,整個系統(tǒng)逐漸碎片化,越來越無序,最終無法維護(hù)和擴(kuò)展,所以系統(tǒng)在一段時間的野蠻生長后,也需要及時干預(yù),避免越來越無序。
在首席架構(gòu)師眼里,架構(gòu)的本質(zhì)是“拆”和“合”。拆是把系統(tǒng)拆分為各個子系統(tǒng)/模塊/組件,拆的時候,首先要解決每個組件的定位問題,然后才能劃分彼此的邊界,實現(xiàn)合理的拆分。合就是根據(jù)最終要求,把各個分離的組件有機(jī)整合在一起,相對來說,第一步的拆分更難。
拆分的結(jié)果使開發(fā)人員能夠做到業(yè)務(wù)聚焦、技能聚焦,實現(xiàn)開發(fā)敏捷,合的結(jié)果是系統(tǒng)變得柔性,可以因需而變,實現(xiàn)業(yè)務(wù)敏捷。
架構(gòu)師應(yīng)該具有的能力
王慶友老師表示,對架構(gòu)師能力要求比較全面,具體來說,需要以下能力:
1. 首先他必須是一個出色的程序員,對代碼和系統(tǒng)有很好的駕駑能力。
2. 要有技術(shù)的廣度(多領(lǐng)域知識),還要有深度(技術(shù)前瞻),對主流公司的系統(tǒng)設(shè)計非常了解,知道優(yōu)劣長短,碰到實際問題,很快有多種方案可供評估。
3. 抽象思維是架構(gòu)師最重要的能力,架構(gòu)師要善于把實物概念化并歸類。
4. 透過問題看本質(zhì)則是由虛到實,往深層次地挖掘,快速識別木桶的短板并解決。
5. 要有良好的溝通能力,確保各方對架構(gòu)達(dá)成共識,愿意采取行動;
6. 要有良好的平衡取舍能力,確保架構(gòu)在現(xiàn)有資源約束下是最合理的,理想最終照進(jìn)現(xiàn)實。
作為電商,App服務(wù)端架構(gòu)有哪些特點(diǎn)?
1. 內(nèi)部功能的共性和個性
電商一般會同時有APP和WEB端,它們內(nèi)部共用一套服務(wù)。作為APP服務(wù)端,首先要統(tǒng)一對接內(nèi)部服務(wù),然后針對APP特點(diǎn)做適配,比如數(shù)據(jù)格式轉(zhuǎn)換,聚合內(nèi)部多個服務(wù)以提升傳輸效率等。
2. 統(tǒng)分結(jié)合,多團(tuán)隊合作
電商APP服務(wù)端的功能很多,單獨(dú)的一個團(tuán)隊(team)不可能包攬所有,一般會采用多團(tuán)隊合作的模式,無線團(tuán)隊負(fù)責(zé)系統(tǒng)級的功能(如通信協(xié)議/數(shù)據(jù)封裝、安全、監(jiān)控等),業(yè)務(wù)系統(tǒng)團(tuán)隊負(fù)責(zé)具體業(yè)務(wù)功能。
3. 故障隔離,高可用性
電商APP服務(wù)端接口由多個后端team提供支持,并且在大促的情況下,某些接口調(diào)用量急劇變大,服務(wù)端架構(gòu)必須支持接口資源的相互隔離,避免一個接口出問題,影響APP全部功能。
核心關(guān)注:拓步ERP系統(tǒng)平臺是覆蓋了眾多的業(yè)務(wù)領(lǐng)域、行業(yè)應(yīng)用,蘊(yùn)涵了豐富的ERP管理思想,集成了ERP軟件業(yè)務(wù)管理理念,功能涉及供應(yīng)鏈、成本、制造、CRM、HR等眾多業(yè)務(wù)領(lǐng)域的管理,全面涵蓋了企業(yè)關(guān)注ERP管理系統(tǒng)的核心領(lǐng)域,是眾多中小企業(yè)信息化建設(shè)首選的ERP管理軟件信賴品牌。
轉(zhuǎn)載請注明出處:拓步ERP資訊網(wǎng)http://www.ezxoed.cn/
本文標(biāo)題:聽首席構(gòu)架師論大型APP服務(wù)端架構(gòu)
本文網(wǎng)址:http://www.ezxoed.cn/html/support/11121519808.html