本系列持续更新中
SpringCloud微服务框架01-SpringCloud简介
SpringCloud微服务框架02-Eureka服务注册与发现
SpringCloud微服务框架03 - Ribbon负载均衡
SpringCloud微服务框架04 - Config统一配置中心
文章中设计到的项目源码,会逐步整理到github上。github除了本系列文章设计到的源码信息,还有Spring Cloud整合的项目框架。有同样正在学习Spring Cloud的小伙伴可以加我一起学习交流。
github地址:https://github.com/hack-feng/maple-cloud
本文基于SpringCloud微服务框架2-Eureka服务注册与发现继续编写。
1、Ribbon的概念
Ribbon是一个客户端负载均衡器,它可以很好的控制HTTP和TCP客户端的行为。Feign已经使用Ribbon,所以如果您使用@FeignClient,则本篇也适用。
Ribbon中的中心概念是指定客户端的概念。每个负载均衡器都是这个组件的一部分,它们一起工作来连接到服务器,
并且它们全体都有一个给定的名字。
SpringCloud使用RibbonClientConfguration在ApplicationContext中创建一个新的全体,这包含ILoadBalancer,RestClient和ServerListFilter。
2、Ribbon使用
基于SpringCloud微服务框架2-Eureka服务注册与发现一文。
2.1 maple-eureka-client中pom.xml引用Ribbon依赖
<!-- 负载均衡 --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-ribbon</artifactId> </dependency>
2.2 添加一个MyLoadBalanceConfig.java配置类。用于自定义配置Ribbon。
public class MyLoadBalanceConfig { @Bean public IRule ribbonRule() { // 其中IRule就是所有规则的标准 return new com.netflix.loadbalancer.RandomRule() ; } }
2.3 修改MapleEurekaClientApplication.java主加载类。
添加@RibbonClient(name = "ribbonClient", configuration = MyLoadBalanceConfig.class)用于加载Ribbon自定义的配置。
@EnableDiscoveryClient @SpringBootApplication @RibbonClient(name = "ribbonClient", configuration = MyLoadBalanceConfig.class) public class MapleEurekaClientApplication { public static void main(String[] args) { SpringApplication.run(MapleEurekaClientApplication.class, args); } }
2.4 在TemplateConfig.java添加@LoadBalanced注解。
@Configuration public class TemplateConfig { @Bean @LoadBalanced //负载均衡 public RestTemplate restTemplate(ClientHttpRequestFactory factory){ return new RestTemplate(factory); } @Bean public ClientHttpRequestFactory simpleClientHttpRequestFactory(){ SimpleClientHttpRequestFactory factory = new SimpleClientHttpRequestFactory(); factory.setReadTimeout(15000);//ms factory.setConnectTimeout(15000);//ms return factory; } }
2.5 创建测试类DemoController.java
@RestController @RequestMapping("/demo") public class DemoController { //调用在Eureka注册的实例,对应调用的spring.application.name,不区分大小写 private String PROVIDER_URL = "http://MAPLE-PROVIDER"; @Autowired private RestTemplate restTemplate; @RequestMapping(value = "/test") public @ResponseBody void test(){ //循环10次,模拟调用十次 for (int i = 0; i < 10; i++) { String res = restTemplate.getForEntity(PROVIDER_URL + "/demo/providerDemo" , String.class).getBody(); System.out.println(res); } } }
3、测试Ribbon负载均衡调用
基于SpringCloud微服务框架2-Eureka服务注册与发现中maple-eureka-provider项目,创建一个新的项目maple-eureka-provider2
application.properties配置文件如下
server.port=8088 spring.application.name=maple-provider eureka.client.service-url.defaultZone=http://admin:admin123@master:1111/eureka/
注意spring.application.name=maple-provider要和maple-eureka-provider一致
maple-eureka-provider如果不一致,默认是两个不同的实例。
修改ProviderDemoController.java的返回数据。
@RestController @RequestMapping("/demo") public class ProviderDemoController { @RequestMapping(value = "/providerDemo") @ResponseBody public String providerDemo(){ return "这是项目《maple-eureka-provider2》ProviderDemo的数据"; } }
maple-eureka-provider的ProviderDemoController.java为
@RestController @RequestMapping("/demo") public class ProviderDemoController { @RequestMapping(value = "/providerDemo") @ResponseBody public String providerDemo(){ return "这是项目《maple-eureka-provider》ProviderDemo的数据"; } }
然后启动:maple-eureka-service、maple-eureka-provider、maple-eureka-provider2、maple-eureka-client项目
在浏览器调用http://127.0.0.1:8065/demo/test.do
console打印数据如下