Spring Cloud 生態(tài)圈

研究了一段時間spring boot了準(zhǔn)備向spirng cloud進(jìn)發(fā)镊逝,公司架構(gòu)和項目也全面擁抱了Spring Cloud蹋半。在使用了一段時間后發(fā)現(xiàn)Spring Cloud從技術(shù)架構(gòu)上降低了對大型系統(tǒng)構(gòu)建的要求染突,使我們以非常低的成本(技術(shù)或者硬件)搭建一套高效份企、分布式、容錯的平臺,但Spring Cloud也不是沒有缺點(diǎn)激才,小型獨(dú)立的項目不適合使用,另外對分布式事物的支持暫時也沒有东帅。

Spring Cloud是什么鬼?

Spring Cloud是一個基于Spring Boot實(shí)現(xiàn)的云應(yīng)用開發(fā)工具,它為基于JVM的云應(yīng)用開發(fā)中的配置管理矿咕、服務(wù)發(fā)現(xiàn)碳柱、斷路器福稳、智能路由鼓拧、微代理季俩、控制總線、全局鎖、決策競選都哭、分布式會話和集群狀態(tài)管理等操作提供了一種簡單的開發(fā)方式。

微服務(wù)是可以獨(dú)立部署、水平擴(kuò)展毡代、獨(dú)立訪問(或者有獨(dú)立的數(shù)據(jù)庫)的服務(wù)單元,springcloud就是這些微服務(wù)的大管家,采用了微服務(wù)這種架構(gòu)之后迂烁,項目的數(shù)量會非常多躏结,springcloud做為大管家需要管理好這些微服務(wù),自然需要很多小弟來幫忙。

主要的小弟有:Spring Cloud Config、Spring Cloud Netflix(Eureka、Hystrix、Zuul溉痢、Archaius...)镀娶、Spring Cloud Bus梯码、Spring Cloud for Cloud Foundry、Spring Cloud Cluster好啰、Spring Cloud Consul轩娶、Spring Cloud Security、Spring Cloud Sleuth框往、Spring Cloud Data Flow鳄抒、Spring Cloud Stream、Spring Cloud Task椰弊、Spring Cloud Zookeeper嘁酿、Spring Cloud Connectors、Spring Cloud Starters男应、Spring Cloud CLI,每個小弟身懷獨(dú)門絕技武功高強(qiáng)下面來做一一介紹娱仔。


核心成員

Spring Cloud Netflix

這可是個大boss沐飘,地位僅次于老大,老大各項服務(wù)依賴與它,與各種Netflix OSS組件集成耐朴,組成微服務(wù)的核心借卧,它的小弟主要有Eureka, Hystrix, Zuul, Archaius... 太多了

Netflix Eureka

服務(wù)中心,云端服務(wù)發(fā)現(xiàn)筛峭,一個基于 REST 的服務(wù)铐刘,用于定位服務(wù),以實(shí)現(xiàn)云端中間層服務(wù)發(fā)現(xiàn)和故障轉(zhuǎn)移影晓。這個可是springcloud最牛鼻的小弟镰吵,服務(wù)中心,任何小弟需要其它小弟支持什么都需要從這里來拿挂签,同樣的你有什么獨(dú)門武功的都趕緊過報道疤祭,方便以后其它小弟來調(diào)用;它的好處是你不需要直接找各種什么小弟支持饵婆,只需要到服務(wù)中心來領(lǐng)取勺馆,也不需要知道提供支持的其它小弟在哪里,還是幾個小弟來支持的侨核,反正拿來用就行草穆,服務(wù)中心來保證穩(wěn)定性和質(zhì)量。

Netflix Hystrix

熔斷器搓译,容錯管理工具悲柱,旨在通過熔斷機(jī)制控制服務(wù)和第三方庫的節(jié)點(diǎn),從而對延遲和故障提供更強(qiáng)大的容錯能力。比如突然某個小弟生病了侥衬,但是你還需要它的支持诗祸,然后調(diào)用之后它半天沒有響應(yīng),你卻不知道轴总,一直在等等這個響應(yīng)直颅;有可能別的小弟也正在調(diào)用你的武功絕技,那么當(dāng)請求多之后怀樟,就會發(fā)生嚴(yán)重的阻塞影響老大的整體計劃功偿。這個時候Hystrix就派上用場了,當(dāng)Hystrix發(fā)現(xiàn)某個小弟不在狀態(tài)不穩(wěn)定立馬馬上讓它下線往堡,讓其它小弟來頂上來械荷,或者給你說不用等了這個小弟今天肯定不行,該干嘛趕緊干嘛去別在這排隊了虑灰。

Netflix Zuul

Zuul 是在云平臺上提供動態(tài)路由,監(jiān)控,彈性,安全等邊緣服務(wù)的框架吨瞎。Zuul 相當(dāng)于是設(shè)備和 Netflix 流應(yīng)用的 Web 網(wǎng)站后端所有請求的前門。當(dāng)其它門派來找大哥辦事的時候一定要先經(jīng)過zuul,看下有沒有帶刀子什么的給攔截回去穆咐,或者是需要找那個小弟的直接給帶過去颤诀。

Netflix Archaius

配置管理API字旭,包含一系列配置管理API,提供動態(tài)類型化屬性崖叫、線程安全配置操作遗淳、輪詢框架、回調(diào)機(jī)制等功能心傀∏担可以實(shí)現(xiàn)動態(tài)獲取配置,
原理是每隔60s(默認(rèn)脂男,可配置)從配置源讀取一次內(nèi)容养叛,這樣修改了配置文件后不需要重啟服務(wù)就可以使修改后的內(nèi)容生效,前提使用archaius的API來讀取疆液。

Spring Cloud Config

俗稱的配置中心一铅,配置管理工具包,讓你可以把配置放到遠(yuǎn)程服務(wù)器堕油,集中化管理集群配置潘飘,目前支持本地存儲、Git以及Subversion掉缺。就是以后大家武器卜录、槍火什么的東西都集中放到一起,別隨便自己帶眶明,方便以后統(tǒng)一管理艰毒、升級裝備。

Spring Cloud Bus

事件搜囱、消息總線丑瞧,用于在集群(例如,配置變化事件)中傳播狀態(tài)變化蜀肘,可與Spring Cloud Config聯(lián)合實(shí)現(xiàn)熱部署绊汹。相當(dāng)于水滸傳中日行八百里的神行太保戴宗,確保各個小弟之間消息保持暢通扮宠。

Spring Cloud for Cloud Foundry

Cloud Foundry是VMware推出的業(yè)界第一個開源PaaS云平臺西乖,它支持多種框架、語言坛增、運(yùn)行時環(huán)境获雕、云平臺及應(yīng)用服務(wù),使開發(fā)人員能夠在幾秒鐘內(nèi)進(jìn)行應(yīng)用程序的部署和擴(kuò)展收捣,無需擔(dān)心任何基礎(chǔ)架構(gòu)的問題

其實(shí)就是與CloudFoundry進(jìn)行集成的一套解決方案届案,抱了Cloud Foundry的大腿。

Spring Cloud Cluster

Spring Cloud Cluster將取代Spring Integration罢艾。提供在分布式系統(tǒng)中的集群所需要的基礎(chǔ)功能支持楣颠,如:選舉嫁乘、集群的狀態(tài)一致性、全局鎖球碉、tokens等常見狀態(tài)模式的抽象和實(shí)現(xiàn)。

如果把不同的幫派組織成統(tǒng)一的整體仓蛆,Spring Cloud Cluster已經(jīng)幫你提供了很多方便組織成統(tǒng)一的工具睁冬。

Spring Cloud Consul

Consul 是一個支持多數(shù)據(jù)中心分布式高可用的服務(wù)發(fā)現(xiàn)和配置共享的服務(wù)軟件,由 HashiCorp 公司用 Go 語言開發(fā), 基于 Mozilla Public License 2.0 的協(xié)議進(jìn)行開源. Consul 支持健康檢查,并允許 HTTP 和 DNS 協(xié)議調(diào)用 API 存儲鍵值對.

Spring Cloud Consul 封裝了Consul操作,consul是一個服務(wù)發(fā)現(xiàn)與配置工具看疙,與Docker容器可以無縫集成豆拨。

其它小弟

Spring Cloud Security

基于spring security的安全工具包,為你的應(yīng)用程序添加安全控制能庆。這個小弟很牛鼻專門負(fù)責(zé)整個幫派的安全問題施禾,設(shè)置不同的門派訪問特定的資源,不能把秘籍葵花寶典泄漏了搁胆。

Spring Cloud Sleuth

日志收集工具包弥搞,封裝了Dapper和log-based追蹤以及Zipkin和HTrace操作,為SpringCloud應(yīng)用實(shí)現(xiàn)了一種分布式追蹤解決方案渠旁。

Spring Cloud Data Flow

Data flow 是一個用于開發(fā)和執(zhí)行大范圍數(shù)據(jù)處理其模式包括ETL攀例,批量運(yùn)算和持續(xù)運(yùn)算的統(tǒng)一編程模型和托管服務(wù)。
對于在現(xiàn)代運(yùn)行環(huán)境中可組合的微服務(wù)程序來說顾腊,Spring Cloud data flow是一個原生云可編配的服務(wù)粤铭。使用Spring Cloud data flow,開發(fā)者可以為像數(shù)據(jù)抽取杂靶,實(shí)時分析梆惯,和數(shù)據(jù)導(dǎo)入/導(dǎo)出這種常見用例創(chuàng)建和編配數(shù)據(jù)通道 (data pipelines)。
Spring Cloud data flow 是基于原生云對 spring XD的重新設(shè)計吗垮,該項目目標(biāo)是簡化大數(shù)據(jù)應(yīng)用的開發(fā)垛吗。Spring XD 的流處理和批處理模塊的重構(gòu)分別是基于 spring boot的stream 和 task/batch 的微服務(wù)程序。這些程序現(xiàn)在都是自動部署單元而且他們原生的支持像 Cloud Foundry抱既、Apache YARN职烧、Apache Mesos和Kubernetes 等現(xiàn)代運(yùn)行環(huán)境。
Spring Cloud data flow 為基于微服務(wù)的分布式流處理和批處理數(shù)據(jù)通道提供了一系列模型和最佳實(shí)踐防泵。
Spring Cloud Stream

Spring Cloud Stream是創(chuàng)建消息驅(qū)動微服務(wù)應(yīng)用的框架蚀之。Spring Cloud Stream是基于spring boot創(chuàng)建,用來建立單獨(dú)的/工業(yè)級spring應(yīng)用捷泞,使用spring integration提供與消息代理之間的連接足删。數(shù)據(jù)流操作開發(fā)包,封裝了與Redis,Rabbit锁右、Kafka等發(fā)送接收消息失受。

一個業(yè)務(wù)會牽扯到多個任務(wù)讶泰,任務(wù)之間是通過事件觸發(fā)的,這就是Spring Cloud stream要干的事了

Spring Cloud Task

Spring Cloud Task 主要解決短命微服務(wù)的任務(wù)管理拂到,任務(wù)調(diào)度的工作痪署,比如說某些定時任務(wù)晚上就跑一次,或者某項數(shù)據(jù)分析臨時就跑幾次兄旬。

Spring Cloud Zookeeper

ZooKeeper是一個分布式的狼犯,開放源碼的分布式應(yīng)用程序協(xié)調(diào)服務(wù),是Google的Chubby一個開源的實(shí)現(xiàn)领铐,是Hadoop和Hbase的重要組件悯森。它是一個為分布式應(yīng)用提供一致性服務(wù)的軟件,提供的功能包括:配置維護(hù)绪撵、域名服務(wù)瓢姻、分布式同步、組服務(wù)等音诈。ZooKeeper的目標(biāo)就是封裝好復(fù)雜易出錯的關(guān)鍵服務(wù)幻碱,將簡單易用的接口和性能高效、功能穩(wěn)定的系統(tǒng)提供給用戶改艇。

操作Zookeeper的工具包收班,用于使用zookeeper方式的服務(wù)發(fā)現(xiàn)和配置管理,抱了Zookeeper的大腿谒兄。

Spring Cloud Connectors

Spring Cloud Connectors 簡化了連接到服務(wù)的過程和從云平臺獲取操作的過程摔桦,有很強(qiáng)的擴(kuò)展性,可以利用Spring Cloud Connectors來構(gòu)建你自己的云平臺承疲。

便于云端應(yīng)用程序在各種PaaS平臺連接到后端邻耕,如:數(shù)據(jù)庫和消息代理服務(wù)。

Spring Cloud Starters

Spring Boot式的啟動項目燕鸽,為Spring Cloud提供開箱即用的依賴管理兄世。

Spring Cloud CLI

基于 Spring Boot CLI,可以讓你以命令行方式快速建立云組件啊研。

和Spring boot 是什么關(guān)系

Spring boot 是 Spring 的一套快速配置腳手架御滩,可以基于spring boot 快速開發(fā)單個微服務(wù),Spring Cloud是一個基于Spring Boot實(shí)現(xiàn)的云應(yīng)用開發(fā)工具党远;Spring boot專注于快速削解、方便集成的單個個體,Spring Cloud是關(guān)注全局的服務(wù)治理框架沟娱;spring boot使用了默認(rèn)大于配置的理念氛驮,很多集成方案已經(jīng)幫你選擇好了,能不配置就不配置济似,Spring Cloud很大的一部分是基于Spring boot來實(shí)現(xiàn),可以不基于Spring boot嗎矫废?不可以盏缤。

Spring boot可以離開Spring Cloud獨(dú)立使用開發(fā)項目,但是Spring Cloud離不開Spring boot蓖扑,屬于依賴的關(guān)系唉铜。

spring -> spring booot > spring cloud 這樣的關(guān)系。

Spring Cloud的優(yōu)勢

微服務(wù)的框架那么多比如:dubbo律杠、Kubernetes打毛,為什么就要使用Spring Cloud的呢?

產(chǎn)出于spring大家族俩功,spring在企業(yè)級開發(fā)框架中無人能敵,來頭很大碰声,可以保證后續(xù)的更新诡蜓、完善。比如dubbo現(xiàn)在就差不多死了胰挑,有spring Boot 這個獨(dú)立干將可以省很多事蔓罚,大大小小的活spring boot都搞的挺不錯。作為一個微服務(wù)治理的大家伙瞻颂,考慮的很全面豺谈,幾乎服務(wù)治理的方方面面都考慮到了,方便開發(fā)開箱即用贡这。Spring Cloud 活躍度很高茬末,教程很豐富,遇到問題很容易找到解決方案盖矫,輕輕松松幾行代碼就完成了熔斷丽惭、均衡負(fù)責(zé)、服務(wù)中心的各種平臺功能辈双,

Spring Cloud 也有一個缺點(diǎn)责掏,只能使用Java開發(fā),不適合小型獨(dú)立的項目。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末湃望,一起剝皮案震驚了整個濱河市换衬,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌证芭,老刑警劉巖瞳浦,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異檩帐,居然都是意外死亡术幔,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進(jìn)店門湃密,熙熙樓的掌柜王于貴愁眉苦臉地迎上來诅挑,“玉大人四敞,你說我怎么就攤上這事“瓮祝” “怎么了忿危?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長没龙。 經(jīng)常有香客問我铺厨,道長,這世上最難降的妖魔是什么硬纤? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任解滓,我火速辦了婚禮,結(jié)果婚禮上筝家,老公的妹妹穿的比我還像新娘洼裤。我一直安慰自己,他們只是感情好溪王,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布腮鞍。 她就那樣靜靜地躺著,像睡著了一般莹菱。 火紅的嫁衣襯著肌膚如雪移国。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天道伟,我揣著相機(jī)與錄音迹缀,去河邊找鬼。 笑死蜜徽,一個胖子當(dāng)著我的面吹牛裹芝,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播娜汁,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼嫂易,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了掐禁?” 一聲冷哼從身側(cè)響起怜械,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎傅事,沒想到半個月后缕允,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蹭越,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年障本,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,599評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡驾霜,死狀恐怖案训,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情粪糙,我是刑警寧澤强霎,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站蓉冈,受9級特大地震影響城舞,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜寞酿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一家夺、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧伐弹,春花似錦秦踪、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽柠逞。三九已至昧狮,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間板壮,已是汗流浹背逗鸣。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留绰精,地道東北人撒璧。 一個月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像笨使,于是被迫代替她去往敵國和親卿樱。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,465評論 2 348

推薦閱讀更多精彩內(nèi)容