微服務(wù)系統(tǒng)和數(shù)據(jù)庫設(shè)計方案_第1頁
微服務(wù)系統(tǒng)和數(shù)據(jù)庫設(shè)計方案_第2頁
微服務(wù)系統(tǒng)和數(shù)據(jù)庫設(shè)計方案_第3頁
微服務(wù)系統(tǒng)和數(shù)據(jù)庫設(shè)計方案_第4頁
微服務(wù)系統(tǒng)和數(shù)據(jù)庫設(shè)計方案_第5頁
已閱讀5頁,還剩13頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、微服務(wù)系統(tǒng)和數(shù)據(jù)庫設(shè)計方案1. 微服務(wù)本質(zhì)微服務(wù)架構(gòu)從本質(zhì)上說其實就是分布式架構(gòu),與其說是一種新架構(gòu),不如說是一種微服務(wù)架構(gòu)風(fēng)格。簡單來說,微服務(wù)架構(gòu)風(fēng)格是要開發(fā)一種由多個小服務(wù)組成的應(yīng)用。每個服務(wù)運行于獨立的進程,并且采用輕量級交互。多數(shù)情況下是一個HTTP的資源API。這些服務(wù)具備獨立業(yè)務(wù)能力并可以通過自動化部署方式獨立部署。這種風(fēng)格使最小化集中管理,從而可以使用多種不同的編程語言和數(shù)據(jù)存儲技術(shù)。對于微服務(wù)架構(gòu)系統(tǒng),由于其服務(wù)粒度小,模塊化清晰,因此首先要做的是對系統(tǒng)整體進行功能、服務(wù)規(guī)劃,優(yōu)先考慮如何在交付過程中,從工程實踐出發(fā),組織好代碼結(jié)構(gòu)、配置、測試、部署、運維、監(jiān)控的整個過程,從

2、而有效體現(xiàn)微服務(wù)的獨立性與可部署性。本文將從微服務(wù)系統(tǒng)的設(shè)計階段、開發(fā)階段、測試階段、部署階段進行綜合闡述。理解微服務(wù)架構(gòu)和理念是核心。2. 系統(tǒng)環(huán)境名稱版本說明JDK1.8Spring BootSpring FrameworkRibbonkafkaRabbitMQ3. 微服務(wù)架構(gòu)的挑戰(zhàn)Ø 可靠性:由于采用遠程調(diào)用的方式,任何一個節(jié)點、網(wǎng)絡(luò)出現(xiàn)問題,都將使得服務(wù)調(diào)用失敗,隨著微服務(wù)數(shù)量的增多,潛在故障點也將增多。也就是沒有充分的保障機制,則單點故障會大量增加。Ø 運維要求高:系統(tǒng)監(jiān)控、高可用性、自動化技術(shù)Ø 分布式復(fù)雜性:網(wǎng)絡(luò)延遲、系統(tǒng)容錯、分布式事務(wù)Ø

3、 部署依賴性強:服務(wù)依賴、多版本問題Ø 性能(服務(wù)間通訊成本高):無狀態(tài)性、進程間調(diào)用、跨網(wǎng)絡(luò)調(diào)用Ø 數(shù)據(jù)一致性:分布式事務(wù)管理需要跨越多個節(jié)點來保證數(shù)據(jù)的瞬時一致性,因此比起傳統(tǒng)的單體架構(gòu)的事務(wù),成本要高得多。另外,在分布式系統(tǒng)中,通常會考慮通過數(shù)據(jù)的最終一致性來解決數(shù)據(jù)瞬時一致帶來的系統(tǒng)不可用。Ø 重復(fù)開發(fā):微服務(wù)理念崇尚每個微服務(wù)作為一個產(chǎn)品看待,有自己的團隊開發(fā),甚至可以有自己完全不同的技術(shù)、框架,那么與其他微服務(wù)團隊的技術(shù)共享就產(chǎn)生了矛盾,重復(fù)開發(fā)的工作即產(chǎn)生了。4. 架構(gòu)設(shè)計4.1. 思維設(shè)計微服務(wù)架構(gòu)設(shè)計的根本目的是實現(xiàn)價值交付,微服務(wù)架構(gòu)只有遵循D

4、evOps理念方可進行的更順暢,思維方式的轉(zhuǎn)變是最重要的。實現(xiàn)微服務(wù)技術(shù)架構(gòu),現(xiàn)有產(chǎn)品需要進行技術(shù)上的改進以及相關(guān)配套服務(wù)的實現(xiàn),采用分階段實施、以及試點產(chǎn)品優(yōu)先實施的策略,主要包括如下:一、技術(shù)上的改進: 1、前后端分離,web前端通過Http/Https協(xié)議調(diào)用微服務(wù)的API網(wǎng)關(guān),由API網(wǎng)關(guān)再經(jīng)過路由服務(wù)調(diào)用相應(yīng)的微服務(wù) 2、不同微服務(wù)之間通過REST方式互相調(diào)用 3、微服務(wù)之間通過消息中間件實現(xiàn)消息交互機制 二、配套服務(wù)與功能實現(xiàn) :1、需要進行相應(yīng)的自動化服務(wù)實現(xiàn),包括自動化構(gòu)建、自動化安裝部署、自動化測試、自動化平臺發(fā)布(Docker實現(xiàn)) 2、管理服務(wù),對于微服務(wù)架構(gòu),必須配套相

5、應(yīng)的監(jiān)控與管理服務(wù)、日志管理服務(wù)等 3、協(xié)作服務(wù),運用DevOps思想提升開發(fā)、測試、運維的高效溝通與協(xié)作,實現(xiàn)開發(fā)與運維的一體化 4.2. 微服務(wù)架構(gòu)設(shè)計架構(gòu)圖1架構(gòu)圖2  1、我們把整個系統(tǒng)根據(jù)業(yè)務(wù)拆分成若干個子系統(tǒng)或微服務(wù)。    2、每個子系統(tǒng)可以部署多個應(yīng)用,多個應(yīng)用之間使用負載均衡。    3、需要一個服務(wù)注冊中心Eureka,所有的服務(wù)都在注冊中心注冊,負載均衡也是通過在注冊中心注冊的服務(wù)來使用一定策略來實現(xiàn)。Eureka可部署多個,進行高可用保證。  

6、0; 4、所有的客戶端都通過同一個網(wǎng)關(guān)地址訪問后臺的服務(wù),通過路由配置ZUUL網(wǎng)關(guān)來判斷一個URL請求由哪個服務(wù)處理。請求轉(zhuǎn)發(fā)到服務(wù)上的時候使用負載均衡Ribbon。    5、服務(wù)之間采用feign進行調(diào)用。    6、使用斷路器hystrix,及時處理服務(wù)調(diào)用時的超時和錯誤,防止由于其中一個服務(wù)的問題而導(dǎo)致整體系統(tǒng)的癱瘓。    7、還需要一個監(jiān)控功能,監(jiān)控每個服務(wù)調(diào)用花費的時間等。 8、使用SpringCloud Config進行統(tǒng)一的配置管理,需要考慮與公司

7、的配置管理平臺如何配合使用。 9、Hystrix,監(jiān)控和斷路器。我們只需要在服務(wù)接口上添加Hystrix標(biāo)簽,就可以實現(xiàn)對這個接口的監(jiān)控和斷路器功能。   10、Hystrix Dashboard,監(jiān)控面板,他提供了一個界面,可以監(jiān)控各個服務(wù)上的服務(wù)調(diào)用所消耗的時間等。    11、Turbine,監(jiān)控聚合,使用Hystrix監(jiān)控,我們需要打開每一個服務(wù)實例的監(jiān)控信息來查看。而Turbine可以幫助我們把所有的服務(wù)實例的監(jiān)控信息聚合到一個地方統(tǒng)一查看。這樣就不需要挨個打開一個個的頁面一個個查看。架構(gòu)的可靠性保證:在關(guān)鍵節(jié)點做

8、主備、集群部署,防止單點故障。待后續(xù)確認問題:1、Access Control:Zuul網(wǎng)關(guān)提供了相關(guān)控制功能,與我司CAS如何結(jié)合使用2、Config Server:Spring Cloud提供了遠程配置中心,與我司的配置管理平臺如何結(jié)合使用5. 設(shè)計階段5.1. 總體設(shè)計1、功能規(guī)劃:對產(chǎn)品功能進行拆分,拆分為若干個微服務(wù);一個功能可以創(chuàng)建多個微服務(wù)并部署在多個服務(wù)器節(jié)點上,以便進行負載均衡。2、設(shè)計原子服務(wù)層,梳理和抽取核心應(yīng)用、公共應(yīng)用,作為獨立的服務(wù)下沉到核心和公共能力層,逐漸形成穩(wěn)定的服務(wù)中心,使應(yīng)用能更快速的響應(yīng)多變的客戶需求。3、為每個服務(wù)設(shè)計API接口(REST方式)4、為不

9、同的服務(wù)進行分類,不同類型的服務(wù)需要的資源不同,可以配置不同的資源,包括CPU、內(nèi)存、存儲等。5.2. 服務(wù)拆分原則1、粒度微小:根據(jù)業(yè)務(wù)功能劃分服務(wù)粒度,總的原則是服務(wù)內(nèi)部高內(nèi)聚,服務(wù)之間低耦合。2、責(zé)任單一:每個服務(wù)只做一件事,即單一職責(zé)原則。3、隔離性原則:每個服務(wù)相互隔離,且不互相影響4、業(yè)務(wù)無關(guān)優(yōu)先原則:基礎(chǔ)服務(wù),是一些基礎(chǔ)組件,與具體的業(yè)務(wù)無關(guān)。比如:短信服務(wù)、郵件服務(wù)。這里的服務(wù)最容易劃分出來做微服務(wù),也是我們第一優(yōu)先級分離出來的服務(wù)。5.3. 服務(wù)規(guī)劃為實現(xiàn)負載均衡,允許相同的服務(wù)在多個節(jié)點注冊相同的服務(wù)名,不同的端口。如果沒有前期的規(guī)劃,不同的服務(wù)提供者可能會注冊相同的服務(wù)名

10、,導(dǎo)致消費者調(diào)用服務(wù)時產(chǎn)生調(diào)用混亂。因此,需進行服務(wù)名的統(tǒng)一規(guī)劃:1、規(guī)劃期統(tǒng)一制定每個服務(wù)提供者的服務(wù)名或者模塊標(biāo)示。2、服務(wù)名的命名規(guī)則:ModuleName_ServiceName,且所有字符小寫,不同單詞之間以下劃線分隔。如用戶管理模塊提供了獲取用戶信息的服務(wù),則命名為:user_get_info。3、新增服務(wù)名時,需要提出申請,審批通過后方可使用,為減少審批復(fù)雜度,可只審批ModuleName,即在模塊內(nèi)部可以自由增加服務(wù)名,不需要進行審批。5.4. 開發(fā)策略總體原則:不同的微服務(wù)需進行物理隔離。1、SVN策略:SVN上創(chuàng)建獨立的分支,不同微服務(wù)的代碼提交不受相互影響; -由配置管理

11、員統(tǒng)一控制。 問題:開發(fā)分支與集成分支,都將增加很多,維護工作量增加。2、編譯策略:代碼編譯時,各個微服務(wù)獨立編譯、打包,杜絕直接的依賴;3、工程構(gòu)建:代碼開發(fā)時,各微服務(wù)創(chuàng)建獨立的工程,工程之間不能產(chǎn)生直接依賴4、持續(xù)集成:每個微服務(wù)獨立執(zhí)行持續(xù)集成。5、版本集成:由統(tǒng)一的集成工具,實現(xiàn)自動化的版本集成,將所有微服務(wù)集成到統(tǒng)一的版本發(fā)布包中。5.5. 版本策略每個微服務(wù)可以獨立制作版本,伴隨著服務(wù)的增多,SVN分支增多,版本也將增多,版本管理的復(fù)雜度將成指數(shù)級增加。在服務(wù)之間依賴較多時,每個服務(wù)的升級或降級都將影響其他服務(wù)的正常運行。因此需執(zhí)行如下策略:1、所有服務(wù)的版本制作交由專業(yè)的版本管

12、理員執(zhí)行。2、采用自動化的版本制作策略,最大程度的減少人工操作。3、每個服務(wù)的版本必須有詳細的版本計劃、版本說明,對于版本說明要制定模板,明確需要提交的內(nèi)容、版本號、SVN標(biāo)簽等。4、對項目經(jīng)理的要求提升,需對整體的版本計劃有嚴格的制定,尤其是版本之間的依賴關(guān)系要非常明確,版本升級、降級的風(fēng)險評估需完全充分。5、接口管理:嚴格執(zhí)行接口管理制度,任何接口的變更必須進行審批、發(fā)公告等流程。5.6. 數(shù)據(jù)庫挑戰(zhàn)與策略每個微服務(wù)都有自己獨立的數(shù)據(jù)庫,那么后臺管理的聯(lián)合查詢怎么處理?這應(yīng)該是大家會普遍遇到的一個問題,有四種處理方案。1)嚴格按照微服務(wù)的劃分來做,微服務(wù)相互獨立,各微服務(wù)數(shù)據(jù)庫也獨立,后臺

13、需要展示數(shù)據(jù)時,調(diào)用各微服務(wù)的接口來獲取對應(yīng)的數(shù)據(jù),再進行數(shù)據(jù)處理后展示出來,這是標(biāo)準(zhǔn)的用法,也是最麻煩的用法。2) 將業(yè)務(wù)高度相關(guān)的表放到一個庫中,將業(yè)務(wù)關(guān)系不是很緊密的表嚴格按照微服務(wù)模式來拆分,這樣既可以使用微服務(wù),也避免了數(shù)據(jù)庫分散導(dǎo)致后臺系統(tǒng)統(tǒng)計功能難以實現(xiàn),是一個折中的方案。3)MySQL+MHA高可用架構(gòu) 、MySQL分布式Proxy水平擴展架構(gòu)、 MySQL緩存高并發(fā)讀架構(gòu)、 MySQL小文件系統(tǒng)大字段存取架構(gòu)、MySQL Inforbright/Greenplum統(tǒng)計分析架構(gòu)。4)數(shù)據(jù)庫嚴格按照微服務(wù)的要求來切分,以滿足業(yè)務(wù)高并發(fā),實時或者準(zhǔn)實時將各微服務(wù)數(shù)據(jù)庫數(shù)據(jù)同步到No

14、SQL數(shù)據(jù)庫中,在同步的過程中進行數(shù)據(jù)清洗,用來滿足后臺業(yè)務(wù)系統(tǒng)的使用,推薦使用MongoDB、HBase等。第一種方案適合業(yè)務(wù)較為簡單的小公司;第二種方案,適合在原有系統(tǒng)之上,慢慢演化為微服務(wù)架構(gòu)的公司;第三種適合大型高并發(fā)的互聯(lián)網(wǎng)公司;第四種適合超大型擴張能力強高并發(fā)公司。建議,我們當(dāng)前采用第二種方案。5.7. 負載均衡不再采用一般的增加負載均衡服務(wù)器的方式進行負載均衡,如F5、Nginx、LVS等,而是把負載均衡的功能以庫的方式集成到服務(wù)消費方的進程內(nèi),這種方案稱為軟負載均衡(Soft Load Balancing)或者客戶端負載均衡。在Spring Cloud中配合Eureka的服務(wù)注

15、冊功能,Ribbon子項目則為REST客戶端實現(xiàn)了負載均衡。使用Ribbon進行負載均衡,其工作原理可以概括為下面四個步驟:1. Ribbon首先根據(jù)其所在Zone優(yōu)先選擇一個負載較少的Eureka Server;2. 定期從Eureka Server更新并過濾服務(wù)實例列表;3. 根據(jù)指定的負載均衡策略,從可用的服務(wù)器列表中選擇一個服務(wù)實例的地址;4. 然后通過RestClient進行服務(wù)調(diào)用。Ribbon本身提供了下面幾種負載均衡策略:· RoundRobinRule: 輪詢策略,Ribbon以輪詢的方式選擇服務(wù)器,這個是默認值。所以示例中所啟動的兩個服務(wù)會被循環(huán)訪問;&

16、#183; RandomRule: 隨機選擇,也就是說Ribbon會隨機從服務(wù)器列表中選擇一個進行訪問;· BestAvailableRule: 最大可用策略,即先過濾出故障服務(wù)器后,選擇一個當(dāng)前并發(fā)請求數(shù)最小的;· WeightedResponseTimeRule: 帶有加權(quán)的輪詢策略,對各個服務(wù)器響應(yīng)時間進行加權(quán)處理,然后在采用輪詢的方式來獲取相應(yīng)的服務(wù)器;· AvailabilityFilteringRule: 可用過濾策略,先過濾出故障的或并發(fā)請求大于閾值一部分服務(wù)實例,然后再以線性輪詢的方式從過濾后的實例清單中選出

17、一個;· ZoneAvoidanceRule: 區(qū)域感知策略,先使用主過濾條件(區(qū)域負載器,選擇最優(yōu)區(qū)域)對所有實例過濾并返回過濾后的實例清單,依次使用次過濾條件列表中的過濾條件對主過濾條件的結(jié)果進行過濾,判斷最小過濾數(shù)(默認1)和最小過濾百分比(默認0),最后對滿足條件的服務(wù)器則使用RoundRobinRule(輪詢方式)選擇一個服務(wù)器實例。5.8. 性能策略1、網(wǎng)絡(luò)優(yōu)化:優(yōu)化組網(wǎng)結(jié)構(gòu),提升網(wǎng)絡(luò)間通訊性能;2、配置優(yōu)化:優(yōu)化Spring Cloud組件集以及其他組件的配置信息,使得性能最大化。5.9. 技術(shù)管理策略微服務(wù)的架構(gòu)理念中指出各微服務(wù)可以獨立建設(shè),可以使用不同的

18、技術(shù)、語言、框架等,以便能更快速的使用新技術(shù)、新框架等響應(yīng)特定客戶需求,解決單體應(yīng)用架構(gòu)更新技術(shù)、更新框架時面臨的困難或阻礙。但這也同時帶來了諸多問題,如下:1、各服務(wù)是否可以任意使用自己的技術(shù)、自己的組件、框架呢?如果這樣,勢必帶來更大的管理困難、維護困難、技術(shù)共享困難。2、公共的方法如何實現(xiàn)共享?如格式化時間的一個簡單方法需要共享,也需要封裝為一個服務(wù)接口嗎?管理策略:1、總體原則:仍然需要進行統(tǒng)籌考慮,所有組件統(tǒng)一管理,組件放置在產(chǎn)品倉庫中,每個產(chǎn)品或服務(wù)需要共享組件時,從產(chǎn)品倉庫獲取。2、特殊情況:特殊服務(wù)需要使用特殊的組件、框架,需提出申請,統(tǒng)籌規(guī)劃后進行決策。6. 開發(fā)階段6.1.

19、 服務(wù)的調(diào)用6.1.1. AIP網(wǎng)關(guān)調(diào)用所有服務(wù)通過Zuul網(wǎng)關(guān)進行調(diào)用,不允許直接調(diào)用微服務(wù)提供者。Zuul可能會成為系統(tǒng)瓶頸,在項目復(fù)雜時可考慮為Zuul進行主備或負載均衡處理。6.1.2. 同步調(diào)用采用HTTP REST方式進行調(diào)用,針對業(yè)務(wù)需求可以進行負載均衡,負載均衡的調(diào)用方式有兩種:1、FeignClient2、RestTemplate建議使用FeignClient方式進行服務(wù)調(diào)用。不管是什么方式,他都是通過REST接口調(diào)用服務(wù)的http接口,參數(shù)和結(jié)果默認都是通過Jackson序列化和反序列化。因為Spring MVC的RestController定義的接口,返回的數(shù)據(jù)都是通過J

20、ackson序列化成JSON數(shù)據(jù)。6.1.3. 異步調(diào)用rabbitMq、kafka、Spring Cloud Stream均是可以選擇的方案。· Spring Cloud Stream,基于 Redis、Rabbit、Kafka 實現(xiàn)的消息微服務(wù),簡單聲明模型用以在 Spring Cloud 應(yīng)用中收發(fā)消息。6.1.4. 服務(wù)間調(diào)用的權(quán)限驗證一般我們的API接口都需要某種授權(quán)才能訪問,登陸成功以后,然后通過token或者cookie等方式才能調(diào)用接口。使用Spring Cloud Netfix框架的話,登錄的時候,把登錄請求轉(zhuǎn)發(fā)到相應(yīng)的用戶服務(wù)上,登陸成功后,會設(shè)置cookie或h

21、eader token等。然后客戶端接下來的請求就會帶著這些驗證信息,從Zuul網(wǎng)關(guān)傳到相應(yīng)的服務(wù)上進行驗證。Zuul網(wǎng)關(guān)在把請求轉(zhuǎn)發(fā)到后臺的服務(wù)的時候,會默認把一些header傳到服務(wù)端,如:Cookie、Set-Cookie、Authorization。這樣,客戶端請求的相關(guān)headers就可以傳遞到服務(wù)端,服務(wù)端設(shè)置的cookie也可以傳到客戶端。但是,如果你想禁止某些header透傳到服務(wù)端,可以在Zuul網(wǎng)關(guān)的application.yml配置里通過下面的方式禁用:zuul:routes:users: path: /users/* sensitiveHeaders: Cookie,S

22、et-Cookie,Authorization serviceId: user剛才說了我們的某個服務(wù)有時候需要調(diào)用另一個服務(wù),這時候,這個請求不是客戶端發(fā)起,他的請求的header里面也不會有任何驗證信息。這時候,要么,通過防火墻等設(shè)置,保證服務(wù)間調(diào)用的接口,只能某幾個地址訪問;要么,就通過某種方式設(shè)置header。同時,如果你想在某個服務(wù)里面獲得這個請求的真是IP,(因為請求的通過網(wǎng)關(guān)轉(zhuǎn)發(fā)而來,你直接通過request獲得ip得到的是網(wǎng)關(guān)的IP),就可以從headerX-Forwarded-Host獲得。如果想禁用這個header,也可以:zuul.addProxyHeaders = fal

23、se如果你使用RestTemplate的方式調(diào)用,可以在請求里面添加一個有header的Options。也可以通過如下的攔截器的方式設(shè)置,它對RestTemplate方式和FeignClient的方式都可以起作用:Beanpublic RequestInterceptor requestInterceptor() return new RequestInterceptor() Override public void apply(RequestTemplate template) String authToken = getToken(); template.header(AUTH_TOKEN

24、_HEADER, authToken); ;6.1.5. 服務(wù)編排主要的作用是減少項目中的相互依賴。比如現(xiàn)在有項目a調(diào)用項目b,項目b調(diào)用項目c.一直到h,是一個調(diào)用鏈,那么項目上線的時候需要先更新最底層的h再更新g.更新c更新b最后是更新項目a。這只是這一個調(diào)用鏈,在復(fù)雜的業(yè)務(wù)中有非常多的調(diào)用,如果要記住每一個調(diào)用鏈對開發(fā)運維人員來說就是災(zāi)難。有這樣一個好辦法可以盡量的減少項目的相互依賴,就是服務(wù)編排,一個核心的業(yè)務(wù)處理項目,負責(zé)和各個微服務(wù)打交道。比如之前是a調(diào)用b,b掉用c,c調(diào)用d,現(xiàn)在統(tǒng)一在一個核心項目W中來處理,W服務(wù)使用a的時候去調(diào)用b,使用b的時候W去調(diào)用c。其實可以理解為面向

25、對象的設(shè)計,減少方法之間的一層層嵌套調(diào)用,而采取一個方法進行業(yè)務(wù)流程的串聯(lián),如方法W實現(xiàn)一個完整的業(yè)務(wù)處理,則采取下面方式:function w()1、調(diào)用方法a;2、調(diào)用方法b;3、調(diào)用方法c;6.2. 服務(wù)的熔斷處理在服務(wù)之間進行調(diào)用時,由于各種原因會導(dǎo)致遠程服務(wù)不可用或壓力過載等異常導(dǎo)致的故障蔓延,此時需要有一種機制進行保護處理。Spring Cloud通過Netflix的Hystrix組件實現(xiàn)熔斷和降級處理解決此問題。斷路器(Cricuit Breaker)是一種能夠在遠程服務(wù)不可用時自動熔斷(打開開關(guān)),并在遠程服務(wù)恢復(fù)時自動恢復(fù)(閉合開關(guān))的設(shè)施,Spring Cloud通過Net

26、flix的Hystrix組件提供斷路器、資源隔離與自我修復(fù)功能。Spring cloud Hystrix 熔斷器6.3. 統(tǒng)一日志管理不同微服務(wù)部署在不同節(jié)點上,登錄每個節(jié)點查看日志是比較麻煩的,同時對于需要關(guān)聯(lián)多個微服務(wù)日志聯(lián)合查看分析的情況將更加麻煩。伴隨節(jié)點數(shù)量的增加,如果沒有合適的管理機制與工具,定位問題、發(fā)現(xiàn)問題的復(fù)雜性將越來越大,將成指數(shù)級增長,因此需要進行統(tǒng)一日志管理。1、建立統(tǒng)一的日志管理規(guī)范;2、開發(fā)并使用統(tǒng)一的日志組件,為所有微服務(wù)提供統(tǒng)一的日志服務(wù),由log4j或Blitz4j封裝;3、在每個服務(wù)節(jié)點上部署日志采集Agent組件,由此Agent進行日志的采集與轉(zhuǎn)發(fā);4、建

27、立統(tǒng)一的日志中心,所有日志寫入日志中心。說明:上述日志的實現(xiàn)由公司的“日志管理平臺”進行實現(xiàn),采用的是ELK集合框架。 6.4. 統(tǒng)一監(jiān)控管理使用Hystrix組件進行服務(wù)的監(jiān)控,使用Nagios進行服務(wù)器等資源的監(jiān)控。1、Hystrix,監(jiān)控和斷路器。我們只需要在服務(wù)接口上添加Hystrix標(biāo)簽,就可以實現(xiàn)對這個接口的監(jiān)控和斷路器功能。  2、Hystrix Dashboard,監(jiān)控面板,他提供了一個界面,可以監(jiān)控各個服務(wù)上的服務(wù)調(diào)用所消耗的時間等。  3、Turbine,監(jiān)控聚合,使用Hystrix監(jiān)控,我們需要打開每一個服務(wù)實例的監(jiān)控信息來查看。而Turbi

28、ne可以幫助我們把所有的服務(wù)實例的監(jiān)控信息聚合到一個地方統(tǒng)一查看。這樣就不需要挨個打開一個個的頁面一個個查看。6.5. 統(tǒng)一配置管理實現(xiàn)各微服務(wù)的統(tǒng)一參數(shù)配置以及版本管理,可采用公司的配置管理平臺或者Spring Cloud Config配置中心。Spring Cloud Config配置中心Spring Cloud Config就是我們通常意義上的配置中心。Spring Cloud Config-把應(yīng)用原本放在本地文件的配置抽取出來放在中心服務(wù)器,本質(zhì)是配置信息從本地遷移到云端。從而能夠提供更好的管理、發(fā)布能力。Spring Cloud Config分服務(wù)端和客戶端,服務(wù)端負責(zé)將git(sv

29、n)中存儲的配置文件發(fā)布成REST接口,客戶端可以從服務(wù)端REST接口獲取配置。但客戶端并不能主動感知到配置的變化,從而主動去獲取新的配置,這需要每個客戶端通過POST方法觸發(fā)各自的/refresh。為解決配置信息能及時通知到各服務(wù),同時減少每個微服務(wù)處理配置信息更新的復(fù)雜度,為此我們通過消息總線來解決此問題,方案如下:1. Git倉庫、Config Server、以及微服務(wù)“Service A”、 “Service B”的實例中都引入了Spring Cloud Bus,所以他們都連接到了RabbitMQ的消息總線上。2. 從Git倉庫中配置的修改到發(fā)起/bus/refresh的POST請求這

30、一步可以通過Git倉庫的Web Hook來自動觸發(fā)。3. /bus/refresh請求不再發(fā)送到具體服務(wù)實例上,而是發(fā)送給Config Server,并通過destination參數(shù)來指定需要更新配置的服務(wù)或?qū)嵗?. 由于所有連接到消息總線上的應(yīng)用都會接受到更新請求,所以在Web Hook中就不需要維護所有節(jié)點內(nèi)容來進行更新,從而解決了通過Web Hook來逐個進行刷新的問題。6.6. 分布式session采用Redis作為緩存組件以及session的共享組件。6.7. REST資源響應(yīng)結(jié)構(gòu)制定規(guī)范和解析方法。6.8. API調(diào)用鏈追蹤微服務(wù)架構(gòu)上通過業(yè)務(wù)來劃分服務(wù)的,通過REST調(diào)用,對外

31、暴露的一個接口,可能需要很多個服務(wù)協(xié)同才能完成這個接口功能,如果鏈路上任何一個服務(wù)出現(xiàn)問題或者網(wǎng)絡(luò)超時,都會形成導(dǎo)致接口調(diào)用失敗。隨著業(yè)務(wù)的不斷擴張,服務(wù)之間互相調(diào)用會越來越復(fù)雜。Spring Cloud Sleuth 主要功能就是在分布式系統(tǒng)中提供追蹤解決方案,并且兼容支持了 zipkin,你只需要在pom文件中引入相應(yīng)的依賴即可。6.9. 單元測試做微服務(wù)架構(gòu),進行系統(tǒng)測試的復(fù)雜度較大,為保證產(chǎn)品質(zhì)量與開發(fā)、測試效率,單元測試是必不可少的??刹捎肕ock方式進行測試模擬,由持續(xù)集成進行自動化單元測試的執(zhí)行以及結(jié)果輸出。6.10. 代碼調(diào)試 對于單體架構(gòu)系統(tǒng),可直接本地化調(diào)試,但對于微服務(wù)架

32、構(gòu),接口間的調(diào)用需采用遠程通訊的方式,也就是說被調(diào)用的服務(wù)必須啟動后方可被調(diào)用,因此當(dāng)微服務(wù)增多時,你可能需要啟動大量的微服務(wù)或者web服務(wù)器,這給本地化調(diào)用與調(diào)試帶來了困難。解決方案待研究。7. 測試7.1. 自動化測試Ø 單元測試:由開發(fā)人員實現(xiàn)。采用Mock方式進行測試模擬,由持續(xù)集成進行自動化單元測試的執(zhí)行以及結(jié)果輸出。Ø 業(yè)務(wù)測試:開發(fā)進行實現(xiàn),測試也需考慮如何實現(xiàn)。將多個服務(wù)或業(yè)務(wù)單元進行串聯(lián),測試一個完整的業(yè)務(wù),甚至是不同業(yè)務(wù)之間組成的系統(tǒng)測試,需要采用相關(guān)的自動化測試框架執(zhí)行,如RobotFramework自動化測試框架。7.2. 依賴測試也可以稱為接口測試或者契約測試,在微服務(wù)逐漸增多的情況下,如何有效保證服務(wù)之間能夠按照接口的約定正常工作,即符合契約,成為微服務(wù)實施過程中,測試面臨的主要挑戰(zhàn)。一、開發(fā)自動化的接口測試工具,1、檢測接口是否滿足約定2、檢測接口是否發(fā)生變化3、檢測接口是否可以正常被調(diào)用。二、測試方法:采取基于消費者驅(qū)動的契約測試,測試架構(gòu)如下:其優(yōu)勢如下:Ø 從價值實現(xiàn)的角度定義契約從消費者使用契約的角度出發(fā),首先保證消費者基于此契約是可以實現(xiàn)價值的,有了這個前提,再使用契約來驗證提供者,如果提供者提供的契約同定義的契約一致,則證明提供

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論