在微服務(wù)落地伊始就逐漸發(fā)力,當(dāng)下已經(jīng)成為Java體系下微服務(wù)框架的代名詞,SpringCloud以Netfilx全家桶作為初始化基礎(chǔ),為開發(fā)人員提供業(yè)務(wù)單元服務(wù)支撐框架的同時(shí),也開發(fā)出一系列的服務(wù)治理SDK,供開發(fā)人員選用。在微服務(wù)發(fā)展背景下,SpringCloud可謂如日中天。DubboDubbo原為阿里巴巴開源的rpc遠(yuǎn)程調(diào)用框架,初始設(shè)計(jì)初衷在于解決以rpc協(xié)議為標(biāo)準(zhǔn)的遠(yuǎn)程服務(wù)調(diào)用問題,隨著阿里巴巴重啟Dubbo,其也開始在服務(wù)治理領(lǐng)域發(fā)力,成為很多以rpc協(xié)議作為通信基礎(chǔ)系統(tǒng)平臺(tái)的。粗略而言,Dubbo和SpringCloud已成為Java體系下的服務(wù)治理“雙”。gRPCgRPC與Dubbo類似,初是由Google開源的一款遠(yuǎn)程服務(wù)調(diào)用框架。gRPC憑借HTTP/2和RrotoBuf服務(wù)定義方式以及多語言支持的特性,加之其易于定制與開發(fā),能夠方面開發(fā)人員進(jìn)行快速擴(kuò)展和靈活發(fā)揮,從而也成為眾多用戶的選擇之一。ServiceMeshServiceMesh的出現(xiàn)不在于它實(shí)現(xiàn)了多少功能,而是它徹底把業(yè)務(wù)單元與業(yè)務(wù)支撐體系分離,完整貫徹了“術(shù)業(yè)有專攻”的思想理念。它允許業(yè)務(wù)人員聚焦業(yè)務(wù)實(shí)現(xiàn),不再關(guān)心服務(wù)治理相關(guān)的內(nèi)容。通過與容器技術(shù)結(jié)合,下沉至基礎(chǔ)設(shè)施,從通信協(xié)議的角度徹底接管業(yè)務(wù)通信交互過程。另一方面,為了快速檢測到故障點(diǎn),甚至盡可能自動(dòng)恢復(fù)服務(wù),實(shí)時(shí)監(jiān)控在微服務(wù)架構(gòu)中也格外重要。廣西Consul微服務(wù)架構(gòu)解決方案
技術(shù)隨業(yè)務(wù)而生,業(yè)務(wù)載技術(shù)而行。近些年來,伴隨數(shù)字經(jīng)濟(jì)的發(fā)展,在眾多企業(yè)的數(shù)字化轉(zhuǎn)型之路上,云原生、DevOps、微服務(wù)、服務(wù)治理等成為行業(yè)內(nèi)不斷被探討的新話題。人們在理解和接受這些新型概念的同時(shí),也不斷地思考其可能的落地形態(tài)。需求是創(chuàng)造發(fā)生的原動(dòng)力,于是一批性的開源技術(shù)或者框架涌現(xiàn)而出:Kubernetes,SpringCloud,ServiceMesh,Serverless……它們炙手可熱,大放異彩。然而在具體落地過程中卻步履維艱,磕磕絆絆。本文試圖結(jié)合企業(yè)業(yè)務(wù)的訴求,以應(yīng)用形態(tài)發(fā)展歷程為背景,幫助企業(yè)梳理應(yīng)用面向云原生、微服務(wù)轉(zhuǎn)型中涉及的各種服務(wù)治理問題,以及服務(wù)治理的發(fā)展趨勢。什么是服務(wù)治理?服務(wù)治理(SOAgovernance),按照AnneThomasManes的定義是:企業(yè)為了確保事情順利完成而實(shí)施的過程,包括佳實(shí)踐、架構(gòu)原則、治理規(guī)程、規(guī)律以及其他決定性的因素。服務(wù)治理指的是用來管理SOA的采用和實(shí)現(xiàn)的過程。由定義可知,服務(wù)治理關(guān)鍵因素在于:應(yīng)用形態(tài)、數(shù)據(jù)采集、信息分析、管控策略和協(xié)議規(guī)范五個(gè)方面。用戶群體只有從這五個(gè)層次出發(fā),才能構(gòu)建出符合企業(yè)規(guī)范與要求的服務(wù)治理平臺(tái),從而進(jìn)一步為企業(yè)創(chuàng)造商業(yè)價(jià)值。01“微觀”塑形。廣西Consul微服務(wù)架構(gòu)解決方案服務(wù)粒度要小,而每個(gè)服務(wù)是針對一個(gè)單一職責(zé)的業(yè)務(wù)能力的封裝,專注做好一件事情。
Docker)與微服務(wù)?Image管理?系統(tǒng)安全管理?授權(quán)管理?系統(tǒng)成熟度?社區(qū)成熟度開發(fā)方式影響隨著持續(xù)交付概念推廣以及Docker容器普及,微服務(wù)將這兩種理念和技術(shù)結(jié)合起來,形成新的微服務(wù)+API+平臺(tái)的開發(fā)模式,提出了容器化微服務(wù)的持續(xù)交付概念。下圖傳統(tǒng)Monolithic的DevOps開發(fā)隊(duì)伍方式:這種整體型架構(gòu)要求產(chǎn)品隊(duì)伍橫跨產(chǎn)品管理Dev開發(fā)QADBA以及系統(tǒng)運(yùn)營管理,而微服務(wù)架構(gòu)引入以后,如下圖:微服務(wù)促進(jìn)了DevOps方式的重組,將一個(gè)大臃腫的整體產(chǎn)品開發(fā)隊(duì)伍切分為根據(jù)不同微服務(wù)的劃分的產(chǎn)品隊(duì)伍,以及一個(gè)大的整體的平臺(tái)隊(duì)伍負(fù)責(zé)運(yùn)營管理,兩者之間通過API交互,做到了松耦合隔絕。首先需要考慮構(gòu)建DevOps能力,這是保證微服務(wù)架構(gòu)在持續(xù)交付和應(yīng)對復(fù)雜運(yùn)維問題的動(dòng)力之源;其次保持服務(wù)持續(xù)演進(jìn),使之能夠快速、低成本地被拆分和合并,以快速響應(yīng)業(yè)務(wù)的變化;同時(shí)要保持團(tuán)隊(duì)和架構(gòu)對齊。微服務(wù)貌似是技術(shù)層面的變革,但它對團(tuán)隊(duì)結(jié)構(gòu)和組織文化有很強(qiáng)的要求和影響。識別和構(gòu)建匹配架構(gòu)的團(tuán)隊(duì)是解決問題的另一大支柱。后,打造持續(xù)改進(jìn)的自組織文化是實(shí)施微服務(wù)的關(guān)鍵基石。只有持續(xù)改進(jìn),持續(xù)學(xué)習(xí)和反饋,持續(xù)打造這樣一個(gè)文化氛圍和團(tuán)隊(duì),微服務(wù)架構(gòu)才能持續(xù)發(fā)展下去。
所有日志數(shù)據(jù)一般集中落地到企業(yè)后臺(tái)日志系統(tǒng),做進(jìn)一步分析和處理。REST/RPC和序列化,框架層要支持將業(yè)務(wù)邏輯以HTTP/REST或者RPC方式暴露出來,HTTP/REST是當(dāng)前主流API暴露方式,在性能要求高的場合則可采用Binary/RPC方式。針對當(dāng)前多樣化的設(shè)備類型(瀏覽器、普通PC、無線設(shè)備等),框架層要支持可定制的序列化機(jī)制,例如,對瀏覽器,框架支持輸出Ajax友好的JSON消息格式,而對無線設(shè)備上的NativeApp,框架支持輸出性能高的Binary消息格式。配置,除了支持普通配置文件方式的配置,框架層還可集成動(dòng)態(tài)運(yùn)行時(shí)配置,能夠在運(yùn)行時(shí)針對不同環(huán)境動(dòng)態(tài)調(diào)整服務(wù)的參數(shù)和配置。限流和容錯(cuò),框架集成限流容錯(cuò)組件,能夠在運(yùn)行時(shí)自動(dòng)限流和容錯(cuò),保護(hù)服務(wù),如果進(jìn)一步和動(dòng)態(tài)配置相結(jié)合,還可以實(shí)現(xiàn)動(dòng)態(tài)限流和熔斷。管理接口,框架集成管理接口,一方面可以在線查看框架和服務(wù)內(nèi)部狀態(tài),同時(shí)還可以動(dòng)態(tài)調(diào)整內(nèi)部狀態(tài),對調(diào)試、監(jiān)控和管理能提供快速反饋。SpringBoot微框架的Actuator模塊就是一個(gè)強(qiáng)大的管理接口。統(tǒng)一錯(cuò)誤處理,對于框架層和服務(wù)的內(nèi)部異常,如果框架層能夠統(tǒng)一處理并記錄日志,對服務(wù)監(jiān)控和快速問題定位有很大幫助。安全。另一方面,還可以通過服務(wù)邊界和服務(wù)協(xié)議方面的演進(jìn)來盡可能減少這樣的關(guān)聯(lián)。
當(dāng)一個(gè)微服務(wù)架構(gòu)系統(tǒng)中服務(wù)個(gè)數(shù)量達(dá)到一定之后,很多開發(fā)團(tuán)隊(duì)對UI測試開始望而卻步,因?yàn)樵谝粋€(gè)存在多個(gè)服務(wù)的系統(tǒng)中(即便單體應(yīng)用系統(tǒng))做集成測試,會(huì)面臨諸多痛點(diǎn):需要維護(hù)完整的運(yùn)行環(huán)境,成本很高。環(huán)境不穩(wěn)定(UI不穩(wěn)定)導(dǎo)致測試隨機(jī)掛,功能增強(qiáng)很容易破壞大量測試。問題難定位,修復(fù)時(shí)間太長,影響Pipeline的推進(jìn)。運(yùn)行速度慢,反饋周期長。存在重復(fù)測試已測試的功能。這些痛點(diǎn)在很大程度上會(huì)削減一個(gè)開發(fā)團(tuán)隊(duì)的生產(chǎn)力,某些企業(yè)會(huì)雇一個(gè)QA進(jìn)行重復(fù)的人工測試從而解放開發(fā)人員的生產(chǎn)力。這種措施有悖于追求的理念,并沒有從本質(zhì)上解決系統(tǒng)的集成的質(zhì)量問題。既然UI測試已經(jīng)不適用引進(jìn)了微服務(wù)架構(gòu)的開發(fā)團(tuán)隊(duì),要如何保證服務(wù)集成的質(zhì)量,我們還需要在自動(dòng)化測試道路上另辟蹊徑。,我們不妨退一步思考,將集成的范圍縮小保證服務(wù)倆倆的集成的可靠性。有了這個(gè)想法,我們開始對服務(wù)倆倆配對做集成測試。測試架構(gòu)演變成:我們需要真實(shí)運(yùn)行待測試的服務(wù),并且對其他服務(wù)使用替身。不難看出這種方式存在以下問題:需要運(yùn)行待集成的真實(shí)服務(wù),存在環(huán)境不穩(wěn)定導(dǎo)致維護(hù)成本增加。需要Mock掉其他服務(wù),增加了額外的工作量。存在大量重復(fù)測試已經(jīng)測試的功能。通常跟微服務(wù)相對的是單體應(yīng)用,即將所有功能都打包成在一個(gè)單元的應(yīng)用程序。邯鄲Zookeeper微服務(wù)架構(gòu)解決方案
微服務(wù)是指開發(fā)單個(gè)小型但有業(yè)務(wù)功能的服務(wù)每個(gè)服務(wù)有自己處理和輕量通訊機(jī)制可以部署在單個(gè)多個(gè)服務(wù)器上。廣西Consul微服務(wù)架構(gòu)解決方案
所以這種能力需要系統(tǒng)單獨(dú)提供。還有一些企業(yè)級關(guān)注的系統(tǒng)問題,比如,安全策略如何集中管理?系統(tǒng)故障如何快速審計(jì)和跟蹤到具體服務(wù)?整個(gè)系統(tǒng)狀態(tài)如何監(jiān)控?服務(wù)之間的依賴關(guān)系如何管理?等等這些問題都不是單個(gè)微服務(wù)考慮的范疇,而需要有一個(gè)系統(tǒng)性的考慮和設(shè)計(jì),讓每個(gè)微服務(wù)都能夠按照系統(tǒng)性的要求和約束提供對應(yīng)的安全性,可靠性,可維護(hù)性的能力。API為什么很重要?服務(wù)價(jià)值的精華體現(xiàn)?可靠、可用、可讀?只有一次機(jī)會(huì)實(shí)現(xiàn)一個(gè)API網(wǎng)關(guān)作為所有客戶端的入口。API網(wǎng)關(guān)有兩種方式來處理請求。有些請求被簡單地代理/路由到合適的服務(wù)上,其他的請求被轉(zhuǎn)給到一組服務(wù)。相比于提供普適的API,API網(wǎng)關(guān)根據(jù)不同的客戶端開放不同的API。比如,NetflixAPI網(wǎng)關(guān)運(yùn)行著客戶端特定的適配器代碼,會(huì)向客戶端提供適合其需求的API。API網(wǎng)關(guān)也可以實(shí)現(xiàn)安全性,比如驗(yàn)證客戶端是否被授權(quán)進(jìn)行某請求。設(shè)計(jì)要素?Version?RequstID?Auth&Signature?RateLimit?Docs?ErrorCode&Message微服務(wù)治理?按需伸縮–部署與監(jiān)控運(yùn)維成本?部署–機(jī)器數(shù)量與部署成本?業(yè)務(wù)–服務(wù)依賴、治理。廣西Consul微服務(wù)架構(gòu)解決方案
首匯信息技術(shù)河北有限公司發(fā)展規(guī)模團(tuán)隊(duì)不斷壯大,現(xiàn)有一支專業(yè)技術(shù)團(tuán)隊(duì),各種專業(yè)設(shè)備齊全。在首匯信息技術(shù)近多年發(fā)展歷史,公司旗下現(xiàn)有品牌中臺(tái)系統(tǒng)等。公司不僅*提供專業(yè)的計(jì)算機(jī)硬件技術(shù)研發(fā)、技術(shù)咨詢、技術(shù)服務(wù);計(jì)算機(jī)系統(tǒng)集成服務(wù);貨物或技術(shù)進(jìn)出口(國家限制和禁止的除外);互聯(lián)網(wǎng)信息服務(wù)(憑許可證經(jīng)營);設(shè)計(jì)、制作、代理國內(nèi)廣告業(yè)務(wù);發(fā)布國內(nèi)戶外廣告業(yè)務(wù);汽車配件、機(jī)械設(shè)備、五金產(chǎn)品、電子產(chǎn)品、化工產(chǎn)品(危險(xiǎn)化學(xué)品及易制毒化學(xué)品除外、無存儲(chǔ))、橡膠制品(醫(yī)用橡膠制品除外)、通信設(shè)備(衛(wèi)星電視廣播地面接收設(shè)施除外)、儀器儀表、安全技術(shù)防范設(shè)備、辦公設(shè)備的批發(fā)、零售。(依法需經(jīng)批準(zhǔn)的項(xiàng)目,經(jīng)相關(guān)部門批準(zhǔn)后方可開展經(jīng)營活動(dòng)),同時(shí)還建立了完善的售后服務(wù)體系,為客戶提供良好的產(chǎn)品和服務(wù)。首匯信息技術(shù)河北有限公司主營業(yè)務(wù)涵蓋信息化中臺(tái)系統(tǒng)規(guī)劃,中臺(tái)ERP服務(wù)平臺(tái),堅(jiān)持“質(zhì)量保證、良好服務(wù)、顧客滿意”的質(zhì)量方針,贏得廣大客戶的支持和信賴。