SpringCloud Ribbon 负载均衡的实现

网友投稿 436 2023-01-15


SpringCloud Ribbon 负载均衡的实现

前言

Ribbon是一个客户端负载均衡器,它提供了对HTTP和TCP客户端的行为的大量控制。我们在上篇(猛戳:SpringCloud系列——Feign 服务调用)已经实现了多个服务之间的Feign调用,服务消费者调用服务提供者,本文记http://录Feign调用Ribbon负载均衡的服务提供者

github地址:https://github.com/Netflix/ribbon

官方文档:https://cloud.spring.io/spring-cloud-static/spring-cloud-netflix/2.1.0.RC2/single/spring-cloud-netflix.html

服务提供者

服务提供者有两个,实际上可以看做只有一个,因为这两个只有端口不同

maven引入Ribbon

org.springframework.cloud

spring-cloud-starter-netflix-ribbon

创建RibbonConfig文件,主类添加@RibbonClient(name = "RibbonConfig", configuration = RibbonConfig.class),我这里偷懒,直接在主类中创建内部类

@EnableEurekaClient

@RibbonClient(name = "RibbonConfig", configuration = RibbonConfig.class)

@SpringBootApplication

public class SpringbootSpringdataJpaApplication{

public static void main(String[] args) {

SpringApplication.run(SpringbootSpringdataJpaApplication.class, args);

}

}

@Configuration

class RibbonConfig {

@Bean

public IRule ribbonRule(){

return new RandomRule(); //分配策略:随机选择一个server

// return new BestAvailableRule(); //分配策略:选择一个最小的并发请求的server,逐个考察Server,如果Server被tripped了,则忽略

// return new RoundRobinRule(); //分配策略:轮询选择,轮询index,选择index对应位置的server

// return new WeightedResponseTimeRule(); //分配策略:根据响应时间分配一个weight(权重),响应时间越长,weight越小,被选中的可能性越低

// return new ZoneAvoidanceRule(); //分配策略:复合判断server所在区域的性能和server的可用性选择server

// return new RetryRule(); //分配策略:对选定的负载均衡策略机上重试机制,在一个配置时间段内当选择server不成功,则一直尝试使用subRule的方式选择一个可用的server

}

@Bean

public IPing ribbonPing() {

return new PingUrl();

}

@Bean

public ServerListSubsetFilter serverListFilter() {

ServerListSubsetFilter filter = new ServerListSubsetFilter();

return filter;

}

}

下表显示了Spring Cloud Netflix默认为Ribbon提供的bean:

官网例子:

我们添加一个测试接口

@RestController

@RequestMapping("/user")

public class UserController {

@RequestMapping("/ribbon")

public String ribbon() {

return "springdatejpa -- 我的端口是:10088";

}

}

第二个服务提供者也是这样配置,注意:应用名要相同(spring.application.name=springdatejpa);端口不同;

服务消费者

服务消费者使用Feign调用,无需做任何修改,Feign已经使用Ribbon。具体配置请戳:SpringCloud系列——Feign 服务调用

@FeignClient(name = "springdatejpa", path = "/user/")

public interface MyspringbootFeign {

@RequestMapping("/ribbon")

String ribbon();

}

/**

* feign调用

*/

@GetMapping("feign/ribbon")

String ribbon(){

return myspringbootFeign.ribbon();

}

效果

启动所有项目,我们注册了三个服务,其中:

有两个服务名称相同、处理的业务相同、端口不同,这两台作为服务提供者(可看做是一个“小集群”);

另一个是服务消费者(Feign调用);

消费者不断调用,Ribbon会从注册中心的服务列表拉取实例集合进行负载均衡调用背后的服务提供者

后记

Ribbon负载均衡已经可以实现,更多配置请看官方文档


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:java实现微信支付结果通知
下一篇:SpringCloud Zuul实现动态路由
相关文章

 发表评论

暂时没有评论,来抢沙发吧~