大話springcloud
研究了一段時間spring boot了準備向spirng cloud進發(fā),公司架構(gòu)和項目也全面擁抱了Spring Cloud。在使用了一段時間后發(fā)現(xiàn)Spring Cloud從技術(shù)架構(gòu)上降低了對大型系統(tǒng)構(gòu)建的要求,使我們以非常低的成本(技術(shù)或者硬件)搭建一套高效、分布式、容錯的平臺,但Spring Cloud也不是沒有缺點,小型獨立的項目不適合使用,另外對分布式事物的支持暫時也沒有。
Spring Cloud是什么鬼?
Spring Cloud是一個基于Spring Boot實現(xiàn)的云應(yīng)用開發(fā)工具,它為基于JVM的云應(yīng)用開發(fā)中的配置管理、服務(wù)發(fā)現(xiàn)、斷路器、智能路由、微代理、控制總線、全局鎖、決策競選、分布式會話和集群狀態(tài)管理等操作提供了一種簡單的開發(fā)方式。
微服務(wù)是可以獨立部署、水平擴展、獨立訪問(或者有獨立的數(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,每個小弟身懷獨門絕技武功高強下面來做一一介紹。
核心成員
Spring Cloud Netflix
這可是個大boss,地位僅次于老大,老大各項服務(wù)依賴與它,與各種Netflix OSS組件集成,組成微服務(wù)的核心,它的小弟主要有Eureka, Hystrix, Zuul, Archaius... 太多了
Netflix Eureka
服務(wù)中心,云端服務(wù)發(fā)現(xiàn),一個基于 REST 的服務(wù),用于定位服務(wù),以實現(xiàn)云端中間層服務(wù)發(fā)現(xiàn)和故障轉(zhuǎn)移。這個可是springcloud最牛鼻的小弟,服務(wù)中心,任何小弟需要其它小弟支持什么都需要從這里來拿,同樣的你有什么獨門武功的都趕緊過報道,方便以后其它小弟來調(diào)用;它的好處是你不需要直接找各種什么小弟支持,只需要到服務(wù)中心來領(lǐng)取,也不需要知道提供支持的其它小弟在哪里,還是幾個小弟來支持的,反正拿來用就行,服務(wù)中心來保證穩(wěn)定性和質(zhì)量。
Netflix Hystrix
熔斷器,容錯管理工具,旨在通過熔斷機制控制服務(wù)和第三方庫的節(jié)點,從而對延遲和故障提供更強大的容錯能力。比如突然某個小弟生病了,但是你還需要它的支持,然后調(diào)用之后它半天沒有響應(yīng),你卻不知道,一直在等等這個響應(yīng);有可能別的小弟也正在調(diào)用你的武功絕技,那么當請求多之后,就會發(fā)生嚴重的阻塞影響老大的整體計劃。這個時候Hystrix就派上用場了,當Hystrix發(fā)現(xiàn)某個小弟不在狀態(tài)不穩(wěn)定立馬馬上讓它下線,讓其它小弟來頂上來,或者給你說不用等了這個小弟今天肯定不行,該干嘛趕緊干嘛去別在這排隊了。
Netflix Zuul
Zuul 是在云平臺上提供動態(tài)路由,監(jiān)控,彈性,安全等邊緣服務(wù)的框架。Zuul 相當于是設(shè)備和 Netflix 流應(yīng)用的 Web 網(wǎng)站后端所有請求的前門。當其它門派來找大哥辦事的時候一定要先經(jīng)過zuul,看下有沒有帶刀子什么的給攔截回去,或者是需要找那個小弟的直接給帶過去。
Netflix Archaius
配置管理API,包含一系列配置管理API,提供動態(tài)類型化屬性、線程安全配置操作、輪詢框架、回調(diào)機制等功能。可以實現(xiàn)動態(tài)獲取配置,
原理是每隔60s(默認,可配置)從配置源讀取一次內(nèi)容,這樣修改了配置文件后不需要重啟服務(wù)就可以使修改后的內(nèi)容生效,前提使用archaius的API來讀取。
Spring Cloud Config
俗稱的配置中心,配置管理工具包,讓你可以把配置放到遠程服務(wù)器,集中化管理集群配置,目前支持本地存儲、Git以及Subversion。就是以后大家武器、槍火什么的東西都集中放到一起,別隨便自己帶,方便以后統(tǒng)一管理、升級裝備。
Spring Cloud Bus
事件、消息總線,用于在集群(例如,配置變化事件)中傳播狀態(tài)變化,可與Spring Cloud Config聯(lián)合實現(xiàn)熱部署。相當于水滸傳中日行八百里的神行太保戴宗,確保各個小弟之間消息保持暢通。
Spring Cloud for Cloud Foundry
Cloud Foundry是VMware推出的業(yè)界第一個開源PaaS云平臺,它支持多種框架、語言、運行時環(huán)境、云平臺及應(yīng)用服務(wù),使開發(fā)人員能夠在幾秒鐘內(nèi)進行應(yīng)用程序的部署和擴展,無需擔心任何基礎(chǔ)架構(gòu)的問題
其實就是與CloudFoundry進行集成的一套解決方案,抱了Cloud Foundry的大腿。
Spring Cloud Cluster
Spring Cloud Cluster將取代Spring Integration。提供在分布式系統(tǒng)中的集群所需要的基礎(chǔ)功能支持,如:選舉、集群的狀態(tài)一致性、全局鎖、tokens等常見狀態(tài)模式的抽象和實現(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é)議進行開源. Consul 支持健康檢查,并允許 HTTP 和 DNS 協(xié)議調(diào)用 API 存儲鍵值對.
Spring Cloud Consul 封裝了Consul操作,consul是一個服務(wù)發(fā)現(xiàn)與配置工具,與Docker容器可以無縫集成。
其它小弟
Spring Cloud Security
基于spring security的安全工具包,為你的應(yīng)用程序添加安全控制。這個小弟很牛鼻專門負責整個幫派的安全問題,設(shè)置不同的門派訪問特定的資源,不能把秘籍葵花寶典泄漏了。
Spring Cloud Sleuth
日志收集工具包,封裝了Dapper和log-based追蹤以及Zipkin和HTrace操作,為SpringCloud應(yīng)用實現(xiàn)了一種分布式追蹤解決方案。
Spring Cloud Data Flow
-
Data flow 是一個用于開發(fā)和執(zhí)行大范圍數(shù)據(jù)處理其模式包括ETL,批量運算和持續(xù)運算的統(tǒng)一編程模型和托管服務(wù)。
-
對于在現(xiàn)代運行環(huán)境中可組合的微服務(wù)程序來說,Spring Cloud data flow是一個原生云可編配的服務(wù)。使用Spring Cloud data flow,開發(fā)者可以為像數(shù)據(jù)抽取,實時分析,和數(shù)據(jù)導(dǎo)入/導(dǎo)出這種常見用例創(chuàng)建和編配數(shù)據(jù)通道 (data pipelines)。
-
Spring Cloud data flow 是基于原生云對 spring XD的重新設(shè)計,該項目目標是簡化大數(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)代運行環(huán)境。
-
Spring Cloud data flow 為基于微服務(wù)的分布式流處理和批處理數(shù)據(jù)通道提供了一系列模型和最佳實踐。
Spring Cloud Stream
Spring Cloud Stream是創(chuàng)建消息驅(qū)動微服務(wù)應(yīng)用的框架。Spring Cloud Stream是基于spring boot創(chuàng)建,用來建立單獨的/工業(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一個開源的實現(xiàn),是Hadoop和Hbase的重要組件。它是一個為分布式應(yīng)用提供一致性服務(wù)的軟件,提供的功能包括:配置維護、域名服務(wù)、分布式同步、組服務(wù)等。ZooKeeper的目標就是封裝好復(fù)雜易出錯的關(guān)鍵服務(wù),將簡單易用的接口和性能高效、功能穩(wěn)定的系統(tǒng)提供給用戶。
操作Zookeeper的工具包,用于使用zookeeper方式的服務(wù)發(fā)現(xiàn)和配置管理,抱了Zookeeper的大腿。
Spring Cloud Connectors
Spring Cloud Connectors 簡化了連接到服務(wù)的過程和從云平臺獲取操作的過程,有很強的擴展性,可以利用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實現(xiàn)的云應(yīng)用開發(fā)工具;Spring boot專注于快速、方便集成的單個個體,Spring Cloud是關(guān)注全局的服務(wù)治理框架;spring boot使用了默認大于配置的理念,很多集成方案已經(jīng)幫你選擇好了,能不配置就不配置,Spring Cloud很大的一部分是基于Spring boot來實現(xiàn),可以不基于Spring boot嗎?不可以。
Spring boot可以離開Spring Cloud獨立使用開發(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 這個獨立干將可以省很多事,大大小小的活spring boot都搞的挺不錯。
- 作為一個微服務(wù)治理的大家伙,考慮的很全面,幾乎服務(wù)治理的方方面面都考慮到了,方便開發(fā)開箱即用。
- Spring Cloud 活躍度很高,教程很豐富,遇到問題很容易找到解決方案
- 輕輕松松幾行代碼就完成了熔斷、均衡負責、服務(wù)中心的各種平臺功能
Spring Cloud 也有一個缺點,只能使用Java開發(fā),不適合小型獨立的項目。

責任編輯:售電衡衡
- 相關(guān)閱讀
- 泛在電力物聯(lián)網(wǎng)
- 電動汽車
- 儲能技術(shù)
- 智能電網(wǎng)
- 電力通信
- 電力軟件
- 高壓技術(shù)
-
權(quán)威發(fā)布 | 新能源汽車產(chǎn)業(yè)頂層設(shè)計落地:鼓勵“光儲充放”,有序推進氫燃料供給體系建設(shè)
2020-11-03新能源,汽車,產(chǎn)業(yè),設(shè)計 -
中國自主研制的“人造太陽”重力支撐設(shè)備正式啟運
2020-09-14核聚變,ITER,核電 -
探索 | 既耗能又可供能的數(shù)據(jù)中心 打造融合型綜合能源系統(tǒng)
2020-06-16綜合能源服務(wù),新能源消納,能源互聯(lián)網(wǎng)
-
新基建助推 數(shù)據(jù)中心建設(shè)將迎爆發(fā)期
2020-06-16數(shù)據(jù)中心,能源互聯(lián)網(wǎng),電力新基建 -
泛在電力物聯(lián)網(wǎng)建設(shè)下看電網(wǎng)企業(yè)數(shù)據(jù)變現(xiàn)之路
2019-11-12泛在電力物聯(lián)網(wǎng) -
泛在電力物聯(lián)網(wǎng)建設(shè)典型實踐案例
2019-10-15泛在電力物聯(lián)網(wǎng)案例
-
新基建之充電樁“火”了 想進這個行業(yè)要“心里有底”
2020-06-16充電樁,充電基礎(chǔ)設(shè)施,電力新基建 -
燃料電池汽車駛?cè)雽こ0傩占疫€要多久?
-
備戰(zhàn)全面電動化 多部委及央企“定調(diào)”充電樁配套節(jié)奏
-
權(quán)威發(fā)布 | 新能源汽車產(chǎn)業(yè)頂層設(shè)計落地:鼓勵“光儲充放”,有序推進氫燃料供給體系建設(shè)
2020-11-03新能源,汽車,產(chǎn)業(yè),設(shè)計 -
中國自主研制的“人造太陽”重力支撐設(shè)備正式啟運
2020-09-14核聚變,ITER,核電 -
能源革命和電改政策紅利將長期助力儲能行業(yè)發(fā)展
-
探索 | 既耗能又可供能的數(shù)據(jù)中心 打造融合型綜合能源系統(tǒng)
2020-06-16綜合能源服務(wù),新能源消納,能源互聯(lián)網(wǎng) -
5G新基建助力智能電網(wǎng)發(fā)展
2020-06-125G,智能電網(wǎng),配電網(wǎng) -
從智能電網(wǎng)到智能城市