這篇文章將為大家詳細(xì)講解有關(guān)SpringCloud中怎么實(shí)現(xiàn)Ribbon負(fù)載均衡,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。
創(chuàng)新互聯(lián)建站專注于突泉企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè)公司,商城網(wǎng)站開發(fā)。突泉網(wǎng)站建設(shè)公司,為突泉等地區(qū)提供建站服務(wù)。全流程按需開發(fā),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)建站專業(yè)和態(tài)度為您提供的服務(wù)
結(jié)構(gòu)下圖所示。
一、服務(wù)器端
1、創(chuàng)建項(xiàng)目
開發(fā)工具:IntelliJ IDEA 2019.2.3
IDEA中創(chuàng)建一個新的SpringBoot項(xiàng)目,名稱為“cloud-server”,SpringBoot版本選擇2.1.10,在選擇Dependencies(依賴)的界面勾選Spring Cloud Discovert ->
Eureka Server,創(chuàng)建完成后的pom.xml配置文件自動添加SpringCloud最新穩(wěn)定版本依賴,當(dāng)前為Greenwich.SR3。
pom.xml完整內(nèi)容如下:
4.0.0 org.springframework.boot spring-boot-starter-parent 2.1.10.RELEASE com.example cloud-server 0.0.1-SNAPSHOT cloud-server Demo project for Spring Boot 1.8 Greenwich.SR3 org.springframework.cloud spring-cloud-starter-netflix-eureka-server org.springframework.boot spring-boot-starter-test test org.springframework.cloud spring-cloud-dependencies ${spring-cloud.version} pom import org.springframework.boot spring-boot-maven-plugin
2、修改配置application.yml
server: port: 8761 eureka: client: register-with-eureka: false fetch-registry: false
3、修改啟動類代碼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)建一個新的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、修改啟動類代碼CloudProviderApplication.java
增加注解@EnableEurekaClient;
讓類在啟動時讀取控制臺輸入,決定使用哪個端口啟動服務(wù)器;
增加一個測試用的控制器方法。
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)建一個新的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、修改啟動類代碼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)新建一個自定義負(fù)載規(guī)則類MyRule.java
Ribbon的負(fù)載均衡器接口定義了服務(wù)器的操作,主要是用于進(jìn)行服務(wù)器選擇。
調(diào)用ILoadBalancer的getAllServers方法可以返回全部服務(wù)器,這里只返回第一個服務(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) { Listservers = 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)新建一個Ping類MyPing.java
負(fù)載均衡器中提供了Ping機(jī)制,每隔一段時間去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 { }
方式二:使用配置文件
把方式一的兩個配置類注釋掉,在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; } }
四、測試
1、啟動服務(wù)器端。
2、啟動兩個服務(wù)提供者,在控制臺中分別輸入8080和8081啟動。
3、啟動服務(wù)調(diào)用者。
4、瀏覽器訪問http://localhost:9000/router,多次刷新頁面,結(jié)果都是:
http://localhost:8081/
服務(wù)調(diào)用者項(xiàng)目IDEA控制臺定時輸出:
自定義服務(wù)器規(guī)則類,輸出服務(wù)器信息: localhost:8081 localhost:8080 自定義Ping類,服務(wù)器信息:localhost:8081,狀態(tài):true 自定義Ping類,服務(wù)器信息:localhost:8080,狀態(tài):true
關(guān)于SpringCloud中怎么實(shí)現(xiàn)Ribbon負(fù)載均衡就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。