日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

基于Spring cloud Ribbon和Eureka实现客户端负载均衡

發(fā)布時間:2025/5/22 javascript 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 基于Spring cloud Ribbon和Eureka实现客户端负载均衡 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

前言

本案例將基于Spring cloud Ribbon和Eureka實現(xiàn)客戶端負載均衡,其中Ribbon用于實現(xiàn)客戶端負載均衡,Eureka主要是用于服務(wù)注冊及發(fā)現(xiàn);

傳統(tǒng)的服務(wù)端負載均衡

常見的服務(wù)端負載均衡有基于nginx實現(xiàn)的,Nginx收到請求后,通過輪詢,IP哈希等算法來決定轉(zhuǎn)發(fā)該請求到哪個服務(wù)來處理,這種方式缺點還是比較多的;

客戶端負載均衡

在微服務(wù)架構(gòu)中,會有很多服務(wù),每個服務(wù)有可能會有多個實例,為了治理這些服務(wù),我們可以通過eureka、consoul、 zookeeper來實現(xiàn),解決完服務(wù)管理后,但是還有問題,如果當(dāng)某個服務(wù)希望調(diào)用其它服務(wù),通常會通過eureka去查詢服務(wù)列表,然后eureka返回該服務(wù)的所有實例,and 然后調(diào)用方應(yīng)該用哪個服務(wù)呢?

這時候,就需要客戶端負載均衡來處理這個問題了,客戶端負載均衡是和應(yīng)用程序綁定在一起的,我們不需要單獨部署一個額外的服務(wù),本文將使用Spring cloud Ribbon,可以幫助客戶端去決定選擇哪個服務(wù)實例來調(diào)用,并可以設(shè)定負載均衡算法;

Netflix ribbon介紹

一個客戶端的負載均衡實現(xiàn),Netflix ribbon提供了以下功能:

1、負載均衡

2、故障容錯

3、支持多種協(xié)議(HTTP, TCP, UDP)

4、緩存

在maven項目中,可以使用以下方式引入:

<dependency><groupId>com.netflix.ribbon</groupId><artifactId>ribbon</artifactId><version>2.2.2</version> </dependency>

Netflix ribbon例子

一種快速創(chuàng)建工程的方法是去https://start.spring.io/網(wǎng)站,添加對應(yīng)的依賴,然后直接下載引入到IDE即可;

1、創(chuàng)建Eureka服務(wù)管理工程

很簡單,主要是要在Spring boot工程里加上@EnableEurekaServer注解,并添加以下application.properties中的配置;

RibbonEurekaServerApplication import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;@SpringBootApplication @EnableEurekaServer public class RibbonEurekaServerApplication {public static void main(String[] args) {SpringApplication.run(RibbonEurekaServerApplication.class, args);} }

application.properties

spring.application.name= ${springboot.app.name:eureka-serviceregistry} server.port = ${server-port:8761} eureka.instance.hostname= ${springboot.app.name:eureka-serviceregistry} eureka.client.registerWithEureka= false eureka.client.fetchRegistry= false eureka.client.serviceUrl.defaultZone: http://${registry.host:localhost}:${server.port}/eureka/

然后啟動,界面如下:

2、創(chuàng)建服務(wù)端工程

首先,建一個controller

@RestController public class MyRestController {@AutowiredEnvironment environment;@GetMapping("/")public String health() {return "I am Ok";}@GetMapping("/backend")public String backend() {System.out.println("Inside MyRestController::backend...");String serverPort = environment.getProperty("local.server.port");System.out.println("Port : " + serverPort);return "Hello form Backend!!! " + " Host : localhost " + " :: Port : " + serverPort;} }

然后新建啟動類,并加上@EnableDiscoveryClient注解

@SpringBootApplication @EnableDiscoveryClient public class RibbonServerApplication {public static void main(String[] args) {SpringApplication.run(RibbonServerApplication.class, args);} }

最后,加上配置文件application.properties

spring.application.name=server server.port = 9090eureka.client.serviceUrl.defaultZone= http://${registry.host:localhost}:${registry.port:8761}/eureka/ eureka.client.healthcheck.enabled= true eureka.instance.leaseRenewalIntervalInSeconds= 1 eureka.instance.leaseExpirationDurationInSeconds= 2

3、創(chuàng)建客戶端工程

注意客戶端工程需要添加spring-cloud-starter-netflix-ribbon依賴;

首先,我們新建啟動類,并加上@RibbonClient@EnableDiscoveryClient注解

@EnableDiscoveryClient @SpringBootApplication @RibbonClient(name = "server", configuration = RibbonConfiguration.class) public class RibbonClientApplication {public static void main(String[] args) {SpringApplication.run(RibbonClientApplication.class, args);} }

注意這里的RibbonConfiguration,是我們的自定義配置類,這里面的方法可以自己根據(jù)情況重寫,本例子只是一個簡單的測試,用的是Ribbon提供的默認方式,代碼如下:

public class RibbonConfiguration {@AutowiredIClientConfig config;@Beanpublic IPing ribbonPing(IClientConfig config) {return new PingUrl();}@Beanpublic IRule ribbonRule(IClientConfig config) {return new AvailabilityFilteringRule();} }

最后,添加application.properties配置文件,如下:

spring.application.name=client server.port=8888eureka.client.serviceUrl.defaultZone= http://${registry.host:localhost}:${registry.port:8761}/eureka/ eureka.client.healthcheck.enabled= true eureka.instance.leaseRenewalIntervalInSeconds= 1 eureka.instance.leaseExpirationDurationInSeconds= 2server.ribbon.eureka.enabled=true #server.ribbon.listOfServers=localhost:9090,localhost:9091,localhost:9092 server.ribbon.ServerListRefreshInterval=1000 #logging.level.root=TRACE

例子測試驗證

首先,打包,然后啟動所有的以上服務(wù),使用java -jar -Dserver.port=XXXX YYYYY.jar命令啟動即可;

啟動后,可以在eureka中看到我們啟動的服務(wù):

由于我們要演示客戶端負載均衡功能,所以再啟動幾個服務(wù)端服務(wù),端口為9091 and 9092,啟動后如下:

OK,準備工作搞好了,可以開測了,點擊http://localhost:8888/client/frontend幾次,結(jié)果如下,,

1、Server Response :: Hello form Backend!!! Host : localhost :: Port : 9090

2、Server Response :: Hello form Backend!!! Host : localhost :: Port : 9092

3、Server Response :: Hello form Backend!!! Host : localhost :: Port : 9091

然后可以再啟動或刪除幾個后端服務(wù),如啟動一個9093端口,在測試一下,9093端口對應(yīng)的服務(wù)也可以訪問到,效果同樣OK。。。

那么,如果只想寫死,從幾個服務(wù)中選擇,而不是自動變動呢,可以在客戶端用以下配置,那么就會一直從這三個服務(wù)中選取了。

server.ribbon.listOfServers=localhost:9090,localhost:9091,localhost:9092

?

轉(zhuǎn)載于:https://www.cnblogs.com/chenpi/p/10514093.html

總結(jié)

以上是生活随笔為你收集整理的基于Spring cloud Ribbon和Eureka实现客户端负载均衡的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。