内容简介:参考:https://blog.csdn.net/chengqiuming/article/details/80711168Ribbon是Netflix发布的负载均衡器,它有助于控制HTTP和TCP的客户端的行为。为Ribbon配置服务提供者地址后,Ribbon就可基于某种负载均衡算法,自动地帮助服务消费者去请求。Ribbon默认为我们提供了很多负载均衡算法,例如轮询、随机等。当然,我们也可为Ribbon实现自定义的负载均衡算法。在Spring Cloud中,当Ribbon与Eureka配合使用时,Ribb
Ribbon简介
参考:https://blog.csdn.net/chengqiuming/article/details/80711168
Ribbon是Netflix发布的负载均衡器,它有助于控制HTTP和TCP的客户端的行为。为Ribbon配置服务提供者地址后,Ribbon就可基于某种负载均衡算法,自动地帮助服务消费者去请求。Ribbon默认为我们提供了很多负载均衡算法,例如轮询、随机等。当然,我们也可为Ribbon实现自定义的负载均衡算法。
在Spring Cloud中,当Ribbon与Eureka配合使用时,Ribbon可自动从Eureka Server获取服务提供者地址列表,并基于负载均衡算法,请求其中一个服务提供者实例。展示了Ribbon与Eureka配合使用时的架构
客户端负责均衡
负载均衡又区分了两种类型:
-
客户端负载均衡(Ribbon)
服务实例的清单在客户端,客户端进行负载均衡算法分配。
(从上面的知识我们已经知道了:客户端可以从Eureka Server中得到一份服务清单,在发送请求时通过负载均衡算法,在多个服务器之间选择一个进行访问) -
服务端负载均衡(Nginx)
服务实例的清单在服务端,服务器进行负载均衡算法分配
客户端负责均衡ribbon
graph TD 服务消费者-->ribbon ribbon-->服务清单1 ribbon-->服务清单2 ribbon-->服务清单3 服务清单1-->eureka里的服务1 服务清单2-->eureka里的服务2 服务清单3-->eureka里的服务3
使用
@EnableDiscoveryClient @SpringBootApplication public class ConsumerMovieApplication { @Bean @LoadBalanced public RestTemplate restTemplate() { return new RestTemplate(); } public static void main(String[] args) { SpringApplication.run(ConsumerMovieApplication.class, args); } }
程序代码,使用负载均衡
@RestController public class MovieController { private static final Logger LOGGER = LoggerFactory.getLogger(MovieController.class); @Autowired private RestTemplate restTemplate; @Autowired private LoadBalancerClient loadBalancerClient; @GetMapping("/user/{id}") public User findById(@PathVariable Long id) { //VIP:virtual IP return this.restTemplate.getForObject("http://microservice-provider-user/" + id, User.class); } @GetMapping("/log-user-instance") public void logUserInstance() { ServiceInstance serviceInstance = this.loadBalancerClient.choose("microservice-provider-user"); // 打印当前选择的是哪个节点 MovieController.LOGGER.info("{}:{}:{}", serviceInstance.getServiceId(), serviceInstance.getHost(), serviceInstance.getPort()); } }
配置
server: port: 8010 spring: application: name: microservice-consumer-movie eureka: client: serviceUrl: defaultZone:http://localhost:8761/eureka/ instance: prefer-ip-address: true
测试
- 启动eureka微服务
- 启动movie-ribbon微服务
- 启动一个user微服务
- 启动第二个user微服务
- 观察eureka的变化
以上所述就是小编给大家介绍的《ribbon客户端负载均衡》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 终于把服务器负载均衡和客户端负载均衡讲清楚了
- 客户端负载均衡-微服务架构
- 客户端负载均衡Ribbon之源码解析
- 客户端负载均衡Spring Cloud Ribbon简介
- golang grpc 客户端负载均衡、重试、健康检查
- 大话微服务」深入聊聊SpringCloud之客户端负载均衡机制
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。