您现在的位置是:主页 > Web前端技术 > Web前端技术
Ribbon如何负载均衡地消费microservice-provider-user开发技术
IDCBT2022-01-10【服务器技术】人已围观
简介这篇文章给大家介绍Ribbon如何负载均衡地消费microservice-provider-user,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 要想消费microservice-provider-user的服务是很简
这篇文章给大家介绍Ribbon如何负载均衡地消费microservice-provider-user,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
要想消费microservice-provider-user的服务是很简单的,我们只需要使用RestTemplate即可,或者例如HttpClient之类的http工具也是可以的。但是在集群环境下,我们必然是每个服务部署多个实例,那么服务消费者消费服务提供者时的负载均衡又要如何做呢?
1.准备工作
启动注册中心:microservice-discovery-eureka
启动服务提供方:microservice-provider-user
修改microservice-provider-user的端口为8001,另外启动一个实例
此时,访问http://discovery:8761
可以在Eureka中看到microservice-provider-user有两个实例在运行。
下面我们创建一个新的微服务(microservice-consumer-movie-*),负载均衡地消费microservice-provider-user的服务。
2.Ribbon介绍
Ribbon是Netflix发布的开源项目,主要功能是提供客户端的软件负载均衡算法,将Netflix的中间层服务连接在一起。Ribbon客户端组件提供一系列完善的配置项如连接超时,重试等。简单的说,就是在配置文件中列出Load Balancer后面所有的机器,Ribbon会自动的帮助你基于某种规则(如简单轮询,随即连接等)去连接这些机器。我们也很容易使用Ribbon实现自定义的负载均衡算法。简单地说,Ribbon是一个客户端负载均衡器。Ribbon工作时分为两步:第一步先选择 Eureka Server, 它优先选择在同一个Zone且负载较少的Server;第二步再根据用户指定的策略,在从Server取到的服务注册列表中选择一个地址。其中Ribbon提供了三种策略:轮询、断路器和根据响应时间加权。
3.开发
创建一个Maven项目,并在pom.xml中加入如下内容:
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://m
aven.apache.org/xsd/maven-4.0.0.xsd">
4.0.0
microservice-consumer-movie-ribbon
jar
com.itmuch.cloud
spring-cloud-microservice-study
0.0.1-SNAPSHOT
org.springframework.cloud
spring-cloud-starter-eureka
org.springframework.cloud
spring-cloud-starter-ribbon
org.springframework.boot
spring-boot-starter-actuator
启动类:MovieRibbonApplication.java。使用@LoadBalanced注解,为RestTemplate开启负载均衡的能力。
@SpringBootApplication
@EnableDiscoveryClient
public class MovieRibbonApplication {
/**
* 实例化RestTemplate,通过@LoadBalanced注解开启均衡负载能力.
* @return restTemplate
*/
@Bean
@LoadBalanced
public RestTemplate restTemplate() {
标签:很赞哦! ()