所有日志數(shù)據(jù)一般集中落地到企業(yè)后臺日志系統(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消息格式。配置,除了支持普通配置文件方式的配置,框架層還可集成動態(tài)運行時配置,能夠在運行時針對不同環(huán)境動態(tài)調(diào)整服務(wù)的參數(shù)和配置。限流和容錯,框架集成限流容錯組件,能夠在運行時自動限流和容錯,保護(hù)服務(wù),如果進(jìn)一步和動態(tài)配置相結(jié)合,還可以實現(xiàn)動態(tài)限流和熔斷。管理接口,框架集成管理接口,一方面可以在線查看框架和服務(wù)內(nèi)部狀態(tài),同時還可以動態(tài)調(diào)整內(nèi)部狀態(tài),對調(diào)試、監(jiān)控和管理能提供快速反饋。SpringBoot微框架的Actuator模塊就是一個強(qiáng)大的管理接口。統(tǒng)一錯誤處理,對于框架層和服務(wù)的內(nèi)部異常,如果框架層能夠統(tǒng)一處理并記錄日志,對服務(wù)監(jiān)控和快速問題定位有很大幫助。安全。把會同時變化的東西放到同一個服務(wù)中,把很少發(fā)生變化的部分放到單獨服務(wù)中,與經(jīng)常發(fā)生變化的部分區(qū)分開。海南輕量級微服務(wù)架構(gòu)設(shè)計
版本管理、事務(wù)處理?技術(shù)多樣性–環(huán)境部署成本、約定成本?運行狀態(tài)治理–監(jiān)控、限流、SLA、LB、日志分析?服務(wù)注冊與發(fā)現(xiàn)?部署–快速、復(fù)制、擴(kuò)容–單機(jī)開發(fā)?調(diào)用–安全、容錯、服務(wù)降級、調(diào)用延時服務(wù)容錯當(dāng)企業(yè)微服務(wù)化以后,服務(wù)之間會有錯綜復(fù)雜的依賴關(guān)系,例如,一個前端請求一般會依賴于多個后端服務(wù),技術(shù)上稱為1->N扇出.在實際生產(chǎn)環(huán)境中,服務(wù)往往不是可靠,服務(wù)可能會出錯或者產(chǎn)生延遲,如果一個應(yīng)用不能對其依賴的故障進(jìn)行容錯和隔離,那么該應(yīng)用本身就處在被拖垮的風(fēng)險中。在一個高流量的網(wǎng)站中,某個單一后端一旦發(fā)生延遲,可能在數(shù)秒內(nèi)導(dǎo)致所有應(yīng)用資源(線程,隊列等)被耗盡,造成所謂的雪崩效應(yīng)(CascadingFailure),嚴(yán)重時可致整個網(wǎng)站癱瘓。服務(wù)依賴服務(wù)框架服務(wù)注冊、發(fā)現(xiàn)、負(fù)載均衡和健康檢查,假定采用進(jìn)程內(nèi)LB方案,那么服務(wù)自注冊一般統(tǒng)一做在服務(wù)器端框架中,健康檢查邏輯由具體業(yè)務(wù)服務(wù)定制,框架層提供調(diào)用健康檢查邏輯的機(jī)制,服務(wù)發(fā)現(xiàn)和負(fù)載均衡則集成在服務(wù)客戶端框架中。監(jiān)控日志,框架一方面要記錄重要的框架層日志、metrics和調(diào)用鏈數(shù)據(jù),還要將日志、metrics等接口暴露出來,讓業(yè)務(wù)層能根據(jù)需要記錄業(yè)務(wù)日志數(shù)據(jù)。在運行環(huán)境中。海南輕量級微服務(wù)架構(gòu)設(shè)計每一個后臺服務(wù)開放一個REST API,許多服務(wù)本身也采用了其它服務(wù)提供的API。
雖然Pair集成測試沒有從根本上解決UI測試的痛點,但它提出了積小成多的理念,該理念告訴我們:只要能夠保證服務(wù)倆倆之間的集成是可靠的,我們就可以相信系統(tǒng)集成也是可靠的。7.引入Contract概念的集成測試就在兩年前,我在珠海出差的某項目上跟小伙伴一起嘗試了一種集成測試方案。當(dāng)時項目采用的是前后端分離開發(fā),后端作為服務(wù)提供者提供RESTfulAPI,前端作為消費者消費API。為了保證前后端開發(fā)人員并行開展工作,我們引入了Contarct概念。前后端開發(fā)人員基于業(yè)務(wù)共同定義API協(xié)議(Contract),該協(xié)議以JSON文件存在于代碼庫的測試資源目錄中,前端在開發(fā)過程中以JSON文件作為測試的斷言依據(jù)。而后端開發(fā)人員則參照該協(xié)議內(nèi)容來實現(xiàn)API。基于這種方案,前后端開發(fā)人員如果都遵守了協(xié)議,聯(lián)調(diào)的過程就會非常順利。而它的優(yōu)勢也很明顯的體現(xiàn)出來:不需要運行其他服務(wù),環(huán)境簡單,運行快。測試可控范圍縮小到單個服務(wù)內(nèi)部。按照Contract,各自編寫代碼并測試。前后端本質(zhì)上等價于服務(wù)提供方和服務(wù)消費方,所以該理念運用在微服務(wù)之間的集成測試中,系統(tǒng)的測試架構(gòu)會得到進(jìn)一步演進(jìn):我么在享受著它帶來的好處的同時,問題也偷偷地潛入系統(tǒng)中。不久后。
斷路器模式源于MartinFowler的CircuitBreaker一文。“斷路器”本身是一種開關(guān)裝置,用于在電路上保護(hù)線路過載,當(dāng)線路中有電器發(fā)生短路時,“斷路器”能夠及時的切斷故障電路,防止發(fā)生過載、發(fā)熱、甚至起火等嚴(yán)重后果。在分布式架構(gòu)中,斷路器模式的作用也是類似的,當(dāng)某個服務(wù)單元發(fā)生故障(類似用電器發(fā)生短路)之后,通過斷路器的故障監(jiān)控(類似熔斷保險絲),直接切斷原來的主邏輯調(diào)用。但是,在Hystrix中的斷路器除了切斷主邏輯的功能之外,還有更復(fù)雜的邏輯,下面我們來看看它更為深層次的處理邏輯。我們來說說斷路器的工作原理,當(dāng)我們把服務(wù)提供者eureka-client中加入了模擬的時間延遲之后,在服務(wù)消費端的服務(wù)降級邏輯因為hystrix命令調(diào)用依賴服務(wù)超時,觸發(fā)了降級邏輯,但是即使這樣,受限于Hystrix超時時間的問題,我們的調(diào)用依然很有可能產(chǎn)生堆積。這個時候斷路器就會發(fā)揮作用,那么斷路器是在什么情況下開始起作用呢?這里涉及到斷路器的三個重要參數(shù):快照時間窗、請求總數(shù)下限、錯誤百分比下限。這個參數(shù)的作用分別是:快照時間窗:斷路器確定是否打開需要統(tǒng)計一些請求和錯誤數(shù)據(jù),而統(tǒng)計的時間范圍就是快照時間窗,默認(rèn)為近的10秒。另一方面,還可以通過服務(wù)邊界和服務(wù)協(xié)議方面的演進(jìn)來盡可能減少這樣的關(guān)聯(lián)。
我們在業(yè)務(wù)實現(xiàn)過程中采用SpringCloud生態(tài)體系,那么我們應(yīng)該優(yōu)先選擇SpringCloud生態(tài)中成熟的網(wǎng)關(guān)組件(畢竟,從升級層面、性能、穩(wěn)定性以及兼容性等角度綜合評估),具體,例如:SpringCloudGateway。若我們的開發(fā)平臺基于Go語言,同理,優(yōu)先評估生態(tài)中所自帶的,然后對通用型產(chǎn)品進(jìn)行評估。除了上述的選型因素外,若我們當(dāng)前的業(yè)務(wù)基于云原生進(jìn)行維護(hù),則我們盡可能選擇其生態(tài)中的組件,比如Traefik組件。1、SpringCloudGatewaySpringCloudGateway是SpringCloud生態(tài)全新項目,其主要基于Spring、SpringBoot和ProjectReactor等技術(shù)開發(fā)的網(wǎng)關(guān)組件,旨在為微服務(wù)架構(gòu)提供簡單、有效和統(tǒng)一的API路由管理方式,同時提供安全性、監(jiān)控/度量和限流,SpringCloudGateway作為SpringCloud生態(tài)系統(tǒng)中的網(wǎng)關(guān),目標(biāo)是替代NetflixZuul組件,其具體架構(gòu)如下所示:2、TraefikTraefik是一個開源的可以使得服務(wù)發(fā)布變得輕松有趣的邊緣路由器。它負(fù)責(zé)接收我們系統(tǒng)的請求,然后使用合適的組件來對這些請求進(jìn)行處理。除此之外,Traefik兼容所有主流的集群技術(shù),比如Kubernetes、Docker、DockerSwarm、AWS、Mesos以及Marathon等等,并且可以同時處理多種方式?;赥raefik。微服務(wù)架構(gòu)用一些功能比較明確、業(yè)務(wù)比較精練的服務(wù)去解決更大、更實際的問題。海南輕量級微服務(wù)架構(gòu)設(shè)計
溝通結(jié)構(gòu)改變設(shè)計結(jié)構(gòu)的一個很有意思的例子是,一些團(tuán)隊會把邏輯塞到自己能夠掌控的應(yīng)用中。海南輕量級微服務(wù)架構(gòu)設(shè)計
RPC也有自己的優(yōu)點,傳輸協(xié)議更高效,安全更可控,特別在一個公司內(nèi)部,如果有統(tǒng)一個的開發(fā)規(guī)范和統(tǒng)一的服務(wù)框架時,他的開發(fā)效率優(yōu)勢更明顯些。就看各自的技術(shù)積累實際條件,自己的選擇了。而異步消息的方式在分布式系統(tǒng)中有特別的應(yīng)用,他既能減低調(diào)用服務(wù)之間的耦合,又能成為調(diào)用之間的緩沖,確保消息積壓不會沖垮被調(diào)用方,同時能保證調(diào)用方的服務(wù)體驗,繼續(xù)干自己該干的活,不至于被后臺性能拖慢。不過需要付出的代價是一致性的減弱,需要接受數(shù)據(jù)終一致性;還有就是后臺服務(wù)一般要實現(xiàn)冪等性,因為消息發(fā)送出于性能的考慮一般會有重復(fù)(保證消息的被收到且收到一次對性能是很大的考驗);后就是必須引入一個的broker,如果公司內(nèi)部沒有技術(shù)積累,對broker分布式管理也是一個很大的挑戰(zhàn)。微服務(wù)優(yōu)點每個微服務(wù)都很小,這樣能聚焦一個指定的業(yè)務(wù)功能或業(yè)務(wù)需求。微服務(wù)能夠被小團(tuán)隊單獨開發(fā),這個小團(tuán)隊是2到5人的開發(fā)人員組成。微服務(wù)是松耦合的,是有功能意義的服務(wù),無論是在開發(fā)階段或部署階段都是的。微服務(wù)能使用不同的語言開發(fā)。微服務(wù)允許容易且靈活的方式集成自動部署,通過持續(xù)集成工具,如Jenkins,bamboo。一個團(tuán)隊的新成員能夠更快投入生產(chǎn)。海南輕量級微服務(wù)架構(gòu)設(shè)計
首匯信息技術(shù)河北有限公司主要經(jīng)營范圍是商務(wù)服務(wù),擁有一支專業(yè)技術(shù)團(tuán)隊和良好的市場口碑。首匯信息技術(shù)致力于為客戶提供良好的信息化中臺系統(tǒng)規(guī)劃,中臺ERP服務(wù)平臺,一切以用戶需求為中心,深受廣大客戶的歡迎。公司將不斷增強(qiáng)企業(yè)重點競爭力,努力學(xué)習(xí)行業(yè)知識,遵守行業(yè)規(guī)范,植根于商務(wù)服務(wù)行業(yè)的發(fā)展。首匯信息技術(shù)憑借創(chuàng)新的產(chǎn)品、專業(yè)的服務(wù)、眾多的成功案例積累起來的聲譽(yù)和口碑,讓企業(yè)發(fā)展再上新高。