簡單了解SpringCloud運行原理
這篇文章主要介紹了簡單了解SpringCloud運行原理,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
SpringCloud是基于SpringBoot這一高度自動化的應(yīng)用開發(fā)框架,將各類業(yè)界比較知名的、得到過實踐反饋的開元服務(wù)治理相關(guān)的技術(shù)框架進(jìn)行優(yōu)化整合的框架,是一種開發(fā)方式的優(yōu)化和組合,,是一組框架的統(tǒng)稱,基于SpringBoot的starter定制,實現(xiàn)開箱即用的目標(biāo),通過簡單的聲明式注解,就能實現(xiàn)服務(wù)的調(diào)用、負(fù)載均衡、限流、熔斷等機制
SpringCloud的核心組件
首先要通過定制一套基于SpringBoot的starter以便快速進(jìn)行框架依賴的集成于配置,所以用springcloud進(jìn)行微服務(wù)開發(fā)時,在項目中通過“spring-cloud-starter-parent”父依賴來實現(xiàn)其他框架級組件的快速引入,雖然只是很簡單的引入了一個父依賴,但是實際上卻是引入了整個SpringBoot的框架體系一級SpringCloud框架體系的整個依賴
核心組件:
SpringCloudStarters:SpringBoot式的啟動項目,為SC提供了開箱即用的依賴管理;
Consul:是一個用Go語言編寫的服務(wù)發(fā)現(xiàn)與配置工具,可作為整個微服務(wù)體系的服務(wù)注冊中心;
Eureka:是一個用java語言編寫的服務(wù)注冊中心;
Feign:是一種聲明式、模塊化的http客戶端,用于簡化微服務(wù)間的調(diào)用行為;
Ribbon:是一個進(jìn)程間通信庫(遠(yuǎn)程過程調(diào)用),內(nèi)置了軟件負(fù)載均衡器,主要的使用模型包括REST調(diào)用,支持各種序列化方案;
Zuul:是一個網(wǎng)關(guān)服務(wù),他提供動態(tài)路由、監(jiān)視、彈性、安全性等等;
Hystrix:是一個延遲和容錯庫,旨在隔離對遠(yuǎn)程系統(tǒng)、服務(wù)和第三方庫的訪問點,停止級聯(lián)故障,并在不可避免的復(fù)雜分布式系統(tǒng)中啟用彈性;
SpringCloudConfig:配置管理工具包,讓你可以把配置放到遠(yuǎn)程服務(wù)器,集中化管理集群配置,目前支持本地存儲、Git以及Subversion;
各個服務(wù)間進(jìn)行通訊調(diào)用的核心問題,也就是通過Feign進(jìn)行客戶端的服務(wù)調(diào)用,微服務(wù)動支持通過Eureka進(jìn)行多節(jié)點集群部署,客戶端調(diào)用時還需要實現(xiàn)負(fù)載均衡等功能,在SpringCloud中是通過Feign框架組合Ribbon框架來實現(xiàn)的
微服務(wù)系統(tǒng)中還要實現(xiàn)限流熔斷的核心問題:服務(wù)的限流和熔斷,如果服務(wù)間的調(diào)用出現(xiàn)阻塞就需要進(jìn)行及時的限流,并通過熔斷來保證服務(wù)的基本可用性,可通過Zuul和Hystrix服務(wù),通過注解的方式來提供這樣的功能機制
服務(wù)的配置管理核心問題:通過SpringCloudConfig 獨立配置服務(wù)管理來實現(xiàn),通過該組件實現(xiàn)SC體系中所喲偶微服務(wù)應(yīng)用配置的集中化管理
SpringCloud的核心注解:
@EnableDiscoveryClient:定義在spring-cloud-commons包中,便于快速實現(xiàn)服務(wù)注冊與發(fā)現(xiàn)的功能注解定義。在主啟動類上定義;
@EnableDiscoveryClient注解的定義中通過“@import({EnableDiscoveryClientImportSelector.class})”類,此類通過定義“isEnable()”方法表示開始服務(wù)注冊與發(fā)現(xiàn)等功能,染紅其父類型“SpringFactoryImportSelector”通過“selectImports()”方法開始掃描eureka繼承的starter依賴包。需要在項目中引入“spring-cloud-starter-consul-discovery”依賴包,這個依賴的“META-INF/spring.factories”文件指向具體依賴“spring-cloud-consul-discovery”,而該依賴中的“META-INF/spring-factories”文件則包含了一系列自動配置類,這些自動配置類會在應(yīng)用啟動時進(jìn)行初始化和加載,完成微服務(wù)與Eureka的連接。
以上說明了SC進(jìn)行微服務(wù)自動發(fā)現(xiàn)注冊配置的基本原理,實際上還是基于SpringBoot的機制來實現(xiàn)的,具體怎樣交互連接的可看“spring-cloud-consul-discovery”的源碼
@EnableFeignClient:用于告訴框架掃描所有通過注解@FeignClient定義的feign客戶端。服務(wù)消費方通過@EnableFeignClients注解開啟配置后,可以通過@FeignClient注解就可以進(jìn)行服務(wù)調(diào)用了,而且實現(xiàn)了客戶端負(fù)載均衡。這個注解默認(rèn)是會默認(rèn)開啟Ribbon代理的,而Ribbon是實現(xiàn)客戶端負(fù)載均衡的一個組件,通過從Eureka拉取服務(wù)節(jié)點信息,從而以輪詢的方式轉(zhuǎn)發(fā)客戶端調(diào)用請求到不同的服務(wù)端節(jié)點來實現(xiàn)負(fù)載均衡。
@EnableCircuitBreake:通過此注解來使用斷路器,該注解會引入Hystrix的配置,其過程與@EnableEurekaClient注解的過程一致,通過導(dǎo)入EnableCircuitBreakerImportSelector類,開啟斷路器設(shè)置,如果項目中引入了“spring-cloud-starter-hystrix”依賴包,那么在應(yīng)用加載時會初始化Hystrix相關(guān)的自動配置類。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- SpringBoot+SpringCloud用戶信息微服務(wù)傳遞實現(xiàn)解析
- 詳解spring cloud如何使用spring-test進(jìn)行單元測試
- Spring Cloud 網(wǎng)關(guān)服務(wù) zuul 動態(tài)路由的實現(xiàn)方法
- Springcloud中的region和zone的使用實例
- springcloud config配置讀取優(yōu)先級過程詳解
- Springcloud-nacos實現(xiàn)配置和注冊中心的方法
- 詳解springcloud 基于feign的服務(wù)接口的統(tǒng)一hystrix降級處理
- springboot2.0和springcloud Finchley版項目搭建(包含eureka,gateWay,F(xiàn)reign,Hystrix)
相關(guān)文章
SpringBoot整合JavaMail實現(xiàn)發(fā)郵件的項目實踐
本文主要介紹了SpringBoot整合JavaMail實現(xiàn)發(fā)郵件的項目實踐,詳細(xì)闡述了使用SpringBoot和JavaMail發(fā)送郵件的步驟,具有一定的參考價值,感興趣的可以了解一下2023-10-10
解決阿里代碼規(guī)范檢測中方法缺少javadoc注釋的問題
這篇文章主要介紹了解決阿里代碼規(guī)范檢測中方法缺少javadoc注釋的問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
Java導(dǎo)入新項目報錯java:JDK?isn‘t?specified?for?module解決辦法
這篇文章主要給大家介紹了關(guān)于Java導(dǎo)入新項目報錯java:JDK?isn‘t?specified?for?module的解決辦法,當(dāng)您在導(dǎo)入Java項目時遇到錯誤時,可以嘗試以下面的方法來處理,需要的朋友可以參考下2024-05-05
Spring session 獲取當(dāng)前賬戶登錄數(shù)的實例代碼
這篇文章主要介紹了Spring session 獲取當(dāng)前賬戶登錄數(shù),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04
劍指Offer之Java算法習(xí)題精講二叉樹專項訓(xùn)練
跟著思路走,之后從簡單題入手,反復(fù)去看,做過之后可能會忘記,之后再做一次,記不住就反復(fù)做,反復(fù)尋求思路和規(guī)律,慢慢積累就會發(fā)現(xiàn)質(zhì)的變化2022-03-03

