亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

目錄
總結
首頁 Java Java基礎 Spring Cloud七大組件是什么

Spring Cloud七大組件是什么

Apr 25, 2021 pm 05:43 PM
java spring boot spring cloud

Spring Cloud七大組件:1、Eureka組件,描述了服務如何進行注冊,注冊到哪里;2、Ribbon組件;3、Feign組件,一個聲明web服務客戶端;4、Hystrix組件;5、Config組件;6、Zuul組件;7、Bus組件。

Spring Cloud七大組件是什么

本教程操作環(huán)境:windows7系統(tǒng)、java8版、DELL G3電腦。

Spring Cloud全家桶組件

在介紹Spring Cloud 全家桶之前,首先要介紹一下Netflix ,Netflix 是一個很偉大的公司,在Spring Cloud項目中占著重要的作用,Netflix 公司提供了包括Eureka、Hystrix、Zuul、Archaius等在內的很多組件,在微服務架構中至關重要,Spring在Netflix 的基礎上,封裝了一系列的組件,命名為:Spring Cloud Eureka、Spring Cloud Hystrix、Spring Cloud Zuul等,下邊對各個組件進行分別得介紹:

(1)Spring Cloud Eureka

我們使用微服務,微服務的本質還是各種API接口的調用,那么我們怎么產生這些接口、產生了這些接口之后如何進行調用那?如何進行管理哪?

答案就是Spring Cloud Eureka,我們可以將自己定義的API 接口注冊到Spring Cloud Eureka上,Eureka負責服務的注冊于發(fā)現(xiàn),如果學習過Zookeeper的話,就可以很好的理解,Eureka的角色和 Zookeeper的角色差不多,都是服務的注冊和發(fā)現(xiàn),構成Eureka體系的包括:服務注冊中心、服務提供者、服務消費者。

這里寫圖片描述

上圖中描述了(圖片來源于網(wǎng)絡):

1、兩臺Eureka服務注冊中心構成的服務注冊中心的主從復制集群;
2、然后服務提供者向注冊中心進行注冊、續(xù)約、下線服務等;
3、服務消費者Eureka注冊中心拉去服務列表并維護在本地(這也是客戶端發(fā)現(xiàn)模式的機制體現(xiàn)!);
4、然后服務消費者根據(jù)從Eureka服務注冊中心獲取的服務列表選取一個服務提供者進行消費服務。

(2)Spring Cloud Ribbon

在上Spring Cloud Eureka描述了服務如何進行注冊,注冊到哪里,服務消費者如何獲取服務生產者的服務信息,但是Eureka只是維護了服務生產者、注冊中心、服務消費者三者之間的關系,真正的服務消費者調用服務生產者提供的數(shù)據(jù)是通過Spring Cloud Ribbon來實現(xiàn)的。

在(1)中提到了服務消費者是將服務從注冊中心獲取服務生產者的服務列表并維護在本地的,這種客戶端發(fā)現(xiàn)模式的方式是服務消費者選擇合適的節(jié)點進行訪問服務生產者提供的數(shù)據(jù),這種選擇合適節(jié)點的過程就是Spring Cloud Ribbon完成的。

Spring Cloud Ribbon客戶端負載均衡器由此而來。

(3)Spring Cloud Feign

上述(1)、(2)中我們已經(jīng)使用最簡單的方式實現(xiàn)了服務的注冊發(fā)現(xiàn)和服務的調用操作,如果具體的使用Ribbon調用服務的話,你就可以感受到使用Ribbon的方式還是有一些復雜,因此Spring Cloud Feign應運而生。

Spring Cloud Feign 是一個聲明web服務客戶端,這使得編寫Web服務客戶端更容易,使用Feign 創(chuàng)建一個接口并對它進行注解,它具有可插拔的注解支持包括Feign注解與JAX-RS注解,F(xiàn)eign還支持可插拔的編碼器與解碼器,Spring Cloud 增加了對 Spring MVC的注解,Spring Web 默認使用了HttpMessageConverters, Spring Cloud 集成 Ribbon 和 Eureka 提供的負載均衡的HTTP客戶端 Feign。

簡單的可以理解為:Spring Cloud Feign 的出現(xiàn)使得Eureka和Ribbon的使用更為簡單。

(4)Spring Cloud Hystrix

我們在(1)、(2)、(3)中知道了使用Eureka進行服務的注冊和發(fā)現(xiàn),使用Ribbon實現(xiàn)服務的負載均衡調用,還知道了使用Feign可以簡化我們的編碼。但是,這些還不足以實現(xiàn)一個高可用的微服務架構。

例如:當有一個服務出現(xiàn)了故障,而服務的調用方不知道服務出現(xiàn)故障,若此時調用放的請求不斷的增加,最后就會等待出現(xiàn)故障的依賴方 相應形成任務的積壓,最終導致自身服務的癱瘓。

Spring Cloud Hystrix正是為了解決這種情況的,防止對某一故障服務持續(xù)進行訪問。Hystrix的含義是:斷路器,斷路器本身是一種開關裝置,用于我們家庭的電路保護,防止電流的過載,當線路中有電器發(fā)生短路的時候,斷路器能夠及時切換故障的電器,防止發(fā)生過載、發(fā)熱甚至起火等嚴重后果。

(5)Spring Cloud Config

對于微服務還不是很多的時候,各種服務的配置管理起來還相對簡單,但是當成百上千的微服務節(jié)點起來的時候,服務配置的管理變得會復雜起來。

分布式系統(tǒng)中,由于服務數(shù)量巨多,為了方便服務配置文件統(tǒng)一管理,實時更新,所以需要分布式配置中心組件。在Spring Cloud中,有分布式配置中心組件Spring Cloud Config ,它支持配置服務放在配置服務的內存中(即本地),也支持放在遠程Git倉庫中。在Cpring Cloud Config 組件中,分兩個角色,一是Config Server,二是Config Client。

Config Server用于配置屬性的存儲,存儲的位置可以為Git倉庫、SVN倉庫、本地文件等,Config Client用于服務屬性的讀取。

這里寫圖片描述

(6)Spring Cloud Zuul

我們使用Spring Cloud Netflix中的Eureka實現(xiàn)了服務注冊中心以及服務注冊與發(fā)現(xiàn);而服務間通過Ribbon或Feign實現(xiàn)服務的消費以及均衡負載;通過Spring Cloud Config實現(xiàn)了應用多環(huán)境的外部化配置以及版本管理。為了使得服務集群更為健壯,使用Hystrix的融斷機制來避免在微服務架構中個別服務出現(xiàn)異常時引起的故障蔓延。

這里寫圖片描述

先來說說這樣架構需要做的一些事兒以及存在的不足:

1、首先,破壞了服務無狀態(tài)特點。為了保證對外服務的安全性,我們需要實現(xiàn)對服務訪問的權限控制,而開放服務的權限控制機制將會貫穿并污染整個開放服務的業(yè)務邏輯,這會帶來的最直接問題是,破壞了服務集群中REST API無狀態(tài)的特點。從具體開發(fā)和測試的角度來說,在工作中除了要考慮實際的業(yè)務邏輯之外,還需要額外可續(xù)對接口訪問的控制處理。

2、其次,無法直接復用既有接口。當我們需要對一個即有的集群內訪問接口,實現(xiàn)外部服務訪問時,我們不得不通過在原有接口上增加校驗邏輯,或增加一個代理調用來實現(xiàn)權限控制,無法直接復用原有的接口。
面對類似上面的問題,我們要如何解決呢?下面進入本文的正題:服務網(wǎng)關!

為了解決上面這些問題,我們需要將權限控制這樣的東西從我們的服務單元中抽離出去,而最適合這些邏輯的地方就是處于對外訪問最前端的地方,我們需要一個更強大一些的均衡負載器,它就是本文將來介紹的:服務網(wǎng)關。

服務網(wǎng)關是微服務架構中一個不可或缺的部分。通過服務網(wǎng)關統(tǒng)一向外系統(tǒng)提供REST API的過程中,除了具備服務路由、均衡負載功能之外,它還具備了權限控制等功能。Spring Cloud Netflix中的Zuul就擔任了這樣的一個角色,為微服務架構提供了前門保護的作用,同時將權限控制這些較重的非業(yè)務邏輯內容遷移到服務路由層面,使得服務集群主體能夠具備更高的可復用性和可測試性。

(7)Spring Cloud Bus

在(5)Spring Cloud Config中,我們知道的配置文件可以通過Config Server存儲到Git等地方,通過Config Client進行讀取,但是我們的配置文件不可能是一直不變的,當我們的配置文件放生變化的時候如何進行更新哪?

一種最簡單的方式重新一下Config Client進行重新獲取,但Spring Cloud絕對不會讓你這樣做的,Spring Cloud Bus正是提供一種操作使得我們在不關閉服務的情況下更新我們的配置。

Spring Cloud Bus官方意義:消息總線。

當然動態(tài)更新服務配置只是消息總線的一個用處,還有很多其他用處。

這里寫圖片描述

總結

Spring Cloud 的組件還不止這些,通過上邊的口水話的介紹,應該可以大致有一定的了解,但是每一個組件的功能遠不止上述介紹的那些,每一個組件還有很多其他的功能點,這里的介紹希望能夠帶大家入個門,不要對微服務這個這么大的概念有所畏懼。

更多編程相關知識,請訪問:編程視頻??!

以上是Spring Cloud七大組件是什么的詳細內容。更多信息請關注PHP中文網(wǎng)其他相關文章!

本站聲明
本文內容由網(wǎng)友自發(fā)貢獻,版權歸原作者所有,本站不承擔相應法律責任。如您發(fā)現(xiàn)有涉嫌抄襲侵權的內容,請聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅動的應用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機

Video Face Swap

Video Face Swap

使用我們完全免費的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級代碼編輯軟件(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
VSCODE設置。JSON位置 VSCODE設置。JSON位置 Aug 01, 2025 am 06:12 AM

settings.json文件位于用戶級或工作區(qū)級路徑,用于自定義VSCode設置。1.用戶級路徑:Windows為C:\Users\\AppData\Roaming\Code\User\settings.json,macOS為/Users//Library/ApplicationSupport/Code/User/settings.json,Linux為/home//.config/Code/User/settings.json;2.工作區(qū)級路徑:項目根目錄下的.vscode/settings

如何使用JDBC處理Java的交易? 如何使用JDBC處理Java的交易? Aug 02, 2025 pm 12:29 PM

要正確處理JDBC事務,必須先關閉自動提交模式,再執(zhí)行多個操作,最后根據(jù)結果提交或回滾;1.調用conn.setAutoCommit(false)以開始事務;2.執(zhí)行多個SQL操作,如INSERT和UPDATE;3.若所有操作成功則調用conn.commit(),若發(fā)生異常則調用conn.rollback()確保數(shù)據(jù)一致性;同時應使用try-with-resources管理資源,妥善處理異常并關閉連接,避免連接泄漏;此外建議使用連接池、設置保存點實現(xiàn)部分回滾,并保持事務盡可能短以提升性能。

在Java的掌握依賴注入春季和Guice 在Java的掌握依賴注入春季和Guice Aug 01, 2025 am 05:53 AM

依賴性(di)IsadesignpatternwhereObjectsReceivedenciesenciesExtern上,推廣looseSecouplingAndEaseerTestingThroughConstructor,setter,orfieldInjection.2.springfraMefringframeWorkSannotationsLikeLikeLike@component@component,@component,@service,@autowiredwithjava-service和@autowiredwithjava-ligatiredwithjava-lase-lightike

如何使用Java的日歷? 如何使用Java的日歷? Aug 02, 2025 am 02:38 AM

使用java.time包中的類替代舊的Date和Calendar類;2.通過LocalDate、LocalDateTime和LocalTime獲取當前日期時間;3.使用of()方法創(chuàng)建特定日期時間;4.利用plus/minus方法不可變地增減時間;5.使用ZonedDateTime和ZoneId處理時區(qū);6.通過DateTimeFormatter格式化和解析日期字符串;7.必要時通過Instant與舊日期類型兼容;現(xiàn)代Java中日期處理應優(yōu)先使用java.timeAPI,它提供了清晰、不可變且線

了解Java虛擬機(JVM)內部 了解Java虛擬機(JVM)內部 Aug 01, 2025 am 06:31 AM

TheJVMenablesJava’s"writeonce,runanywhere"capabilitybyexecutingbytecodethroughfourmaincomponents:1.TheClassLoaderSubsystemloads,links,andinitializes.classfilesusingbootstrap,extension,andapplicationclassloaders,ensuringsecureandlazyclassloa

Google Chrome無法打開本地文件 Google Chrome無法打開本地文件 Aug 01, 2025 am 05:24 AM

ChromecanopenlocalfileslikeHTMLandPDFsbyusing"Openfile"ordraggingthemintothebrowser;ensuretheaddressstartswithfile:///;2.SecurityrestrictionsblockAJAX,localStorage,andcross-folderaccessonfile://;usealocalserverlikepython-mhttp.server8000tor

比較Java框架:Spring Boot vs Quarkus vs Micronaut 比較Java框架:Spring Boot vs Quarkus vs Micronaut Aug 04, 2025 pm 12:48 PM

前形式攝取,quarkusandmicronautleaddueTocile timeProcessingandGraalvSupport,withquarkusoftenpernperforminglightbetterine nosserless notelless centarios.2。

了解網(wǎng)絡端口和防火墻 了解網(wǎng)絡端口和防火墻 Aug 01, 2025 am 06:40 AM

NetworkPortSandFireWallsworkTogetHertoEnableCommunication whereSeringSecurity.1.NetWorkPortSareVirtualendPointSnumbered0-655 35,with-Well-with-Newonportslike80(HTTP),443(https),22(SSH)和25(smtp)sindiessingspefificservices.2.portsoperateervertcp(可靠,c

See all articles