SpringCloud微服务框架03 - Ribbon负载均衡

本系列持续更新中

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打印数据如下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

笑小枫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值