SpringCloud Ribbon負(fù)載均衡實(shí)例解析
這篇文章主要介紹了SpringCloud Ribbon負(fù)載均衡實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
Spring Cloud集成了Ribbon,結(jié)合Eureka,可實(shí)現(xiàn)客戶端的負(fù)載均衡。
下面實(shí)現(xiàn)一個(gè)例子,結(jié)構(gòu)下圖所示。
一、服務(wù)器端
1、創(chuàng)建項(xiàng)目
開(kāi)發(fā)工具:IntelliJ IDEA 2019.2.3
IDEA中創(chuàng)建一個(gè)新的SpringBoot項(xiàng)目,名稱為“cloud-server”,SpringBoot版本選擇2.1.10,在選擇Dependencies(依賴)的界面勾選Spring Cloud Discovert ->
Eureka Server,創(chuàng)建完成后的pom.xml配置文件自動(dòng)添加SpringCloud最新穩(wěn)定版本依賴,當(dāng)前為Greenwich.SR3。
pom.xml完整內(nèi)容如下:
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.10.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.example</groupId> <artifactId>cloud-server</artifactId> <version>0.0.1-SNAPSHOT</version> <name>cloud-server</name> <description>Demo project for Spring Boot</description> <properties> <java.version>1.8</java.version> <spring-cloud.version>Greenwich.SR3</spring-cloud.version> </properties> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>${spring-cloud.version}</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
2、修改配置application.yml
server: port: 8761 eureka: client: register-with-eureka: false fetch-registry: false
3、修改啟動(dòng)類代碼CloudServerApplication.java
增加注解@EnableEurekaServer
package com.example.cloudserver; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer; @SpringBootApplication @EnableEurekaServer public class CloudServerApplication { public static void main(String[] args) { SpringApplication.run(CloudServerApplication.class, args); } }
二、服務(wù)提供者
1、創(chuàng)建項(xiàng)目
IDEA中創(chuàng)建一個(gè)新的SpringBoot項(xiàng)目,除了名稱為“cloud-provider”,其它步驟和上面創(chuàng)建服務(wù)器端一樣。
2、修改配置application.yml
spring: application: name: cloud-provider eureka: instance: hostname: localhost client: serviceUrl: defaultZone: http://localhost:8761/eureka/
3、修改啟動(dòng)類代碼CloudProviderApplication.java
增加注解@EnableEurekaClient;
讓類在啟動(dòng)時(shí)讀取控制臺(tái)輸入,決定使用哪個(gè)端口啟動(dòng)服務(wù)器;
增加一個(gè)測(cè)試用的控制器方法。
package com.example.cloudprovider; //import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.boot.builder.SpringApplicationBuilder; import org.springframework.cloud.netflix.eureka.EnableEurekaClient; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import javax.servlet.http.HttpServletRequest; import java.util.Scanner; @SpringBootApplication @EnableEurekaClient @RestController public class CloudProviderApplication { public static void main(String[] args) { //SpringApplication.run(CloudProviderApplication.class, args); Scanner scan = new Scanner(System.in); String port = scan.nextLine(); new SpringApplicationBuilder(CloudProviderApplication.class).properties("server.port=" + port).run(args); } @RequestMapping("/") public String index(HttpServletRequest request) { return request.getRequestURL().toString(); } }
三、服務(wù)調(diào)用者
1、創(chuàng)建項(xiàng)目
IDEA中創(chuàng)建一個(gè)新的SpringBoot項(xiàng)目,除了名稱為“cloud-invoker”,其它步驟和上面創(chuàng)建服務(wù)器端一樣。
2、修改配置application.yml
server: port: 9000 spring: application: name: cloud-invoker eureka: instance: hostname: localhost client: serviceUrl: defaultZone: http://localhost:8761/eureka/
3、修改啟動(dòng)類代碼CloudInvokerApplication.java
增加注解@EnableDiscoveryClient。
package com.example.cloudinvoker; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.discovery.EnableDiscoveryClient; @SpringBootApplication @EnableDiscoveryClient public class CloudInvokerApplication { public static void main(String[] args) { SpringApplication.run(CloudInvokerApplication.class, args); } }
4、配置Ribbon有2種方式:使用代碼、使用配置文件
方式一:使用代碼
(1)新建一個(gè)自定義負(fù)載規(guī)則類MyRule.java
Ribbon的負(fù)載均衡器接口定義了服務(wù)器的操作,主要是用于進(jìn)行服務(wù)器選擇。
調(diào)用ILoadBalancer的getAllServers方法可以返回全部服務(wù)器,這里只返回第一個(gè)服務(wù)器。
package com.example.cloudinvoker; import com.netflix.loadbalancer.ILoadBalancer; import com.netflix.loadbalancer.IRule; import com.netflix.loadbalancer.Server; import java.util.List; public class MyRule implements IRule { private ILoadBalancer iLoadBalancer; @Override public Server choose(Object o) { List<Server> servers = iLoadBalancer.getAllServers(); System.out.println("自定義服務(wù)器規(guī)則類,輸出服務(wù)器信息:"); for(Server s: servers){ System.out.println(" " + s.getHostPort()); } return servers.get(0); } @Override public void setLoadBalancer(ILoadBalancer iLoadBalancer) { this.iLoadBalancer = iLoadBalancer; } @Override public ILoadBalancer getLoadBalancer() { return this.iLoadBalancer; } }
(2)新建一個(gè)Ping類MyPing.java
負(fù)載均衡器中提供了Ping機(jī)制,每隔一段時(shí)間去Ping服務(wù)器,判斷服務(wù)器是否存活。
該工作由IPing接口的實(shí)現(xiàn)類負(fù)責(zé)。
package com.example.cloudinvoker; import com.netflix.loadbalancer.IPing; import com.netflix.loadbalancer.Server; public class MyPing implements IPing { @Override public boolean isAlive(Server server) { System.out.println("自定義Ping類,服務(wù)器信息:" + server.getHostPort() + ",狀態(tài):" + server.isAlive()); return true; } }
(3)新建配置類MyConfig.java
package com.example.cloudinvoker.config; import com.example.cloudinvoker.MyPing; import com.example.cloudinvoker.MyRule; import com.netflix.loadbalancer.IPing; import com.netflix.loadbalancer.IRule; import org.springframework.context.annotation.Bean; public class MyConfig { @Bean public IRule getRule(){ return new MyRule(); } @Bean public IPing getPing(){ return new MyPing(); } }
(4)新建配置類CloudProviderConfig.java
package com.example.cloudinvoker.config; import org.springframework.cloud.netflix.ribbon.RibbonClient; @RibbonClient(name = "cloud-provider", configuration = MyConfig.class) public class CloudProviderConfig { }
方式二:使用配置文件
把方式一的兩個(gè)配置類注釋掉,在application.yml的最后面添加下面配置
cloud-provider: ribbon: NFLoadBalancerRuleClassName: com.example.cloudinvoker.MyRule NFLoadBalancerPingClassName: com.example.cloudinvoker.MyPing listOfServers: http://localhost:8080/,http://localhost:8081/
5、添加控制器 InvokerController.java
package com.example.cloudinvoker; import org.springframework.cloud.client.loadbalancer.LoadBalanced; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.http.MediaType; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.client.RestTemplate; @RestController @Configuration public class InvokerController { @LoadBalanced @Bean public RestTemplate getRestTemplate(){ return new RestTemplate(); } @RequestMapping(value="/router", method = RequestMethod.GET,produces = MediaType.APPLICATION_JSON_VALUE) public String router(){ RestTemplate restTemplate = getRestTemplate(); //根據(jù)名稱調(diào)用服務(wù) String json = restTemplate.getForObject("http://cloud-provider/", String.class); return json; } }
四、測(cè)試
1、啟動(dòng)服務(wù)器端。
2、啟動(dòng)兩個(gè)服務(wù)提供者,在控制臺(tái)中分別輸入8080和8081啟動(dòng)。
3、啟動(dòng)服務(wù)調(diào)用者。
4、瀏覽器訪問(wèn)http://localhost:9000/router,多次刷新頁(yè)面,結(jié)果都是:
http://localhost:8081/
服務(wù)調(diào)用者項(xiàng)目IDEA控制臺(tái)定時(shí)輸出:
自定義服務(wù)器規(guī)則類,輸出服務(wù)器信息: localhost:8081 localhost:8080 自定義Ping類,服務(wù)器信息:localhost:8081,狀態(tài):true 自定義Ping類,服務(wù)器信息:localhost:8080,狀態(tài):true
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- springcloud中Ribbon和RestTemplate實(shí)現(xiàn)服務(wù)調(diào)用與負(fù)載均衡
- SpringCloud 2020-Ribbon負(fù)載均衡服務(wù)調(diào)用的實(shí)現(xiàn)
- SpringCloud Netflix Ribbon源碼解析(推薦)
- SpringCloud手寫(xiě)Ribbon實(shí)現(xiàn)負(fù)載均衡
- SpringCloud 服務(wù)負(fù)載均衡和調(diào)用 Ribbon、OpenFeign的方法
- Springcloud ribbon負(fù)載均衡算法實(shí)現(xiàn)
- SpringCloud Ribbon負(fù)載均衡代碼實(shí)例
- 詳解SpringCloud Ribbon 負(fù)載均衡通過(guò)服務(wù)器名無(wú)法連接的神坑
- SpringCloud Ribbon 負(fù)載均衡的實(shí)現(xiàn)
- SpringCloud Edgware.SR3版本中Ribbon的timeout設(shè)置方法
- SpringCloud 中使用 Ribbon的方法詳解
- SpringCloud客戶端的負(fù)載均衡Ribbon的實(shí)現(xiàn)
- 詳細(xì)介紹SpringCloud之Ribbon
- 淺談SpringCloud之Ribbon詳解
相關(guān)文章
Java通過(guò)經(jīng)緯度坐標(biāo)獲取兩個(gè)點(diǎn)之間的直線距離的示例
這篇文章主要介紹了Java通過(guò)經(jīng)緯度坐標(biāo)獲取兩個(gè)點(diǎn)之間的直線距離的示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07mybatis insert foreach循環(huán)插入方式
這篇文章主要介紹了mybatis insert foreach循環(huán)插入方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07Java實(shí)現(xiàn)自定義語(yǔ)言和表達(dá)式解析的解釋器模式
Java解釋器設(shè)計(jì)模式通過(guò)解析自定義語(yǔ)言和表達(dá)式,實(shí)現(xiàn)對(duì)復(fù)雜邏輯的處理,提高程序可擴(kuò)展性和靈活性。它將語(yǔ)法解析和執(zhí)行過(guò)程分離,通過(guò)抽象語(yǔ)法樹(shù)和解釋器實(shí)現(xiàn)對(duì)語(yǔ)言和表達(dá)式的解析和求值,避免了硬編碼和復(fù)雜的條件判斷,提高了程序的可讀性和可維護(hù)性2023-04-04Java實(shí)現(xiàn)經(jīng)典游戲飛機(jī)大戰(zhàn)-I的示例代碼
《飛機(jī)大戰(zhàn)-I》是一款融合了街機(jī)、競(jìng)技等多種元素的經(jīng)典射擊手游。本文將利用java語(yǔ)言實(shí)現(xiàn)這游戲,文中采用了swing技術(shù)進(jìn)行了界面化處理,感興趣的可以了解一下2022-02-02修改SpringBoot啟動(dòng)圖標(biāo)banner的兩種方式
Banner即橫幅標(biāo)語(yǔ),我們?cè)趩?dòng)SpringBoot項(xiàng)目時(shí)會(huì)將Banner信息打印至控制臺(tái),我們可以輸出一些圖形、SpringBoot版本信息等內(nèi)容,有很多小伙伴想知道如何修改SpringBoot啟動(dòng)圖標(biāo)banner,接下來(lái)由小編給大家介紹一下吧2024-08-08Java 在volatile內(nèi)部調(diào)用接口的方法
在Java中,volatile?關(guān)鍵字通常用于確保變量的可見(jiàn)性和有序性,而不是用來(lái)修飾接口或方法調(diào)用的,這篇文章主要介紹了Java 在volatile內(nèi)部調(diào)用接口的方法,需要的朋友可以參考下2024-07-07java通過(guò)Idea遠(yuǎn)程一鍵部署springboot到Docker詳解
這篇文章主要介紹了java通過(guò)Idea遠(yuǎn)程一鍵部署springboot到Docker詳解,Idea是Java開(kāi)發(fā)利器,springboot是Java生態(tài)中最流行的微服務(wù)框架,docker是時(shí)下最火的容器技術(shù),那么它們結(jié)合在一起會(huì)產(chǎn)生什么化學(xué)反應(yīng)呢?的相關(guān)資料2019-06-06Spring?Boot實(shí)現(xiàn)文件上傳的兩種方式總結(jié)
應(yīng)用開(kāi)發(fā)過(guò)程中,文件上傳是一個(gè)基礎(chǔ)的擴(kuò)展功能,它的目的就是讓大家共享我們上傳的文件資源,下面這篇文章主要給大家總結(jié)介紹了關(guān)于Spring?Boot實(shí)現(xiàn)文件上傳的兩種方式,需要的朋友可以參考下2023-05-05Spring Boot 實(shí)現(xiàn)敏感詞及特殊字符過(guò)濾處理
這篇文章主要介紹了SpringBoot實(shí)現(xiàn)敏感詞及特殊字符過(guò)濾處理方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06