您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)SpringCloud微服務(wù)基礎(chǔ)知識點,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
SpringCloud 對常見的分布式系統(tǒng)模式提供了簡單易用的編程模型,幫助開發(fā)者構(gòu)建彈性、可靠、協(xié)調(diào)的應(yīng)用程序。
SpringCloud 是在SpringBoot的基礎(chǔ)上構(gòu)建的,使開發(fā)者可以輕松入門并快速提高工作效率。
SpringCloud 提供了一套微服務(wù)解決方案,包括服務(wù)注冊與發(fā)現(xiàn),配置中心,全鏈路監(jiān)控,服務(wù)網(wǎng)關(guān),負(fù)載均衡,熔斷器等組件,除了基于NetFlix的開源組件做高度抽象封裝之外,還有一些選型中立的開源組件。
SpringCloud 為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)架構(gòu)的工具,例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智能路由,微代理,控制總線,一次性令牌,全局鎖定,領(lǐng)導(dǎo)選舉,分布式會話,集群狀態(tài)等。他們都可以用SpringBoot的開發(fā)風(fēng)格做到一鍵啟動和部署。
SpringBoot 并沒有重復(fù)造輪子,它只是將目前各家公司開發(fā)的比較成熟,經(jīng)得起實際考研的服務(wù)框架組合起來,通過SpringBoot風(fēng)格進(jìn)行再封裝,屏蔽掉了復(fù)雜的配置和實現(xiàn)原理,最終給開發(fā)者留出了一套簡單易懂易部署和易維護(hù)的分布式系統(tǒng)開發(fā)工具包。
SpringCloud 是分布式微服務(wù)架構(gòu)下的一站式解決方案,是各個微服務(wù)架構(gòu)落地技術(shù)的集合體,俗稱微服務(wù)全家桶。
SpringBoot 專注于快速方便的開發(fā)單個個體微服務(wù)。
SpringCloud 是關(guān)注全局的微服務(wù)協(xié)調(diào)整理治理框架,它將SpringBoot開發(fā)的一個個單體微服務(wù)整合并管理起來,為各個微服務(wù)之間提供配置管理,服務(wù)發(fā)現(xiàn),斷路器,路由,微代理,事件總線,全局鎖,分布式會話等等集成服務(wù)。
SpringBoot 可以離開 SpringClooud 獨立使用,但是 SpringCloud 離不開 SpringBoot,屬于依賴關(guān)系。
SpringCloud拋棄了Dubbo的RPC通信,采用的是基于HTTP的REST方式。
雖然從一定程度上來說,后者犧牲了服務(wù)調(diào)用的性能,但也避免了上面提到的原生RPC帶來的問題。而且REST相比RPC更為靈活,服務(wù)提供方和調(diào)用方的依賴只依靠一紙契約,不存在代碼級別的強依賴,這在強調(diào)快速演化的微服務(wù)環(huán)境下,顯得更加合適。
Dubbo的定位是一款RPC框架,Spring Cloud的目標(biāo)是微服務(wù)架構(gòu)下的一站式解決方案。
Distributed/versioned configuration(分布式/版本控制配置).
Service registration and discovery(服務(wù)注冊與發(fā)現(xiàn))
Routing(路由)
Service-to-service calls(服務(wù)到服務(wù)的調(diào)用)
.Load balancing (負(fù)載均衡配置)
Circuit Breakers(斷路器)
Distributed messaging (分布式消息管理)
SpringCloud是一個由許多子項目組成的綜合項目,各子項目有不同的發(fā)布節(jié)奏。
為了管理SpringCloud與各子項目的版本依賴關(guān)系,發(fā)布了一個清單,其中包括了某個SpringCloud版本對應(yīng)的子項目版本。
為了避免SpringCloud版本號與子項目版本號混淆,SpringCloud版本采用了名稱而非版本號的命名,這些版本的名字采用了倫敦地鐵站的名字,根據(jù)字母表的順序來對應(yīng)版本時間順序,例如Angel是第一個版本, Brixton是第二個版本。
當(dāng)SpringCloud的發(fā)布內(nèi)容積累到臨界點或者一個重大BUG被解決后,會發(fā)布一個"service releases"版本,簡稱SRX版本,比如Greenwich.SR2就是SpringCloud發(fā)布的Greenwich版本的第2個SRX版本。
Spring Cloud Config
集中配置管理工具,分布式系統(tǒng)中統(tǒng)一的外部配置管理,默認(rèn)使用Git來存儲配置,可以支持客戶端配置的刷新及加密、解密操作。
Spring Cloud Netflix
Netflix OSS 開源組件集成,包括Eureka、Hystrix、Ribbon、Feign、Zuul等核心組件
Eureka
:服務(wù)治理組件,包括服務(wù)端的注冊中心和客戶端的服務(wù)發(fā)現(xiàn)機制;
Ribbon
:負(fù)載均衡的服務(wù)調(diào)用組件,具有多種負(fù)載均衡調(diào)用策略;
Hystrix
:服務(wù)容錯組件,實現(xiàn)了斷路器模式,為依賴服務(wù)的出錯和延遲提供了容錯能力;
Feign
:基于Ribbon和Hystrix的聲明式服務(wù)調(diào)用組件;
Zuul
:API網(wǎng)關(guān)組件,對請求提供路由及過濾功能。
Spring Cloud Bus
用于傳播集群狀態(tài)變化的消息總線,使用輕量級消息代理鏈接分布式系統(tǒng)中的節(jié)點,可以用來動態(tài)刷新集群中的服務(wù)配置。
Spring Cloud Consul
基于Hashicorp Consul的服務(wù)治理組件。
Spring Cloud Security
安全工具包,對Zuul代理中的負(fù)載均衡OAuth3客戶端及登錄認(rèn)證進(jìn)行支持。
Spring Cloud Sleuth
SpringCloud應(yīng)用程序的分布式請求鏈路跟蹤,支持使用Zipkin、HTrace和基于日志(例如ELK)的跟蹤。
Spring Cloud Stream
輕量級事件驅(qū)動微服務(wù)框架,可以使用簡單的聲明式模型來發(fā)送及接收消息,主要實現(xiàn)為Apache Kafka及RabbitMQ。
Spring Cloud Task
用于快速構(gòu)建短暫、有限數(shù)據(jù)處理任務(wù)的微服務(wù)框架,用于向應(yīng)用中添加功能性和非功能性的特性。
Spring Cloud Zookeeper
基于Apache Zookeeper的服務(wù)治理組件。
Spring Cloud Gateway
API網(wǎng)關(guān)組件,對請求提供路由及過濾功能。
Spring Cloud OpenFeign
基于Ribbon和Hystrix的聲明式服務(wù)調(diào)用組件,可以動態(tài)創(chuàng)建基于Spring MVC注解的接口實現(xiàn)用于服務(wù)調(diào)用,在SpringCloud 2.0中已經(jīng)取代Feign成為了一等公民。
關(guān)于“SpringCloud微服務(wù)基礎(chǔ)知識點”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。