上一章主要介绍了注册中心的高可用,地址可见
https://blog.csdn.net/qq_37031675/article/details/104007366
一.说明
我们服务的消费者在调用服务的提供者,为了避免高并发请求对于服务的响应,通常会采用负载均衡,通常web项目使用的是nginx,本文介绍springcloud的另一个组件ribbon
二.代码使用
@Bean
@LoadBalanced
public RestTemplate restTemplate() {
return new RestTemplate();
}
服务调用端,在RestTemplate的ioc过程中添加@LoadBalanced注解
public static final String PRODUCT_GET_URL = "http://MICROCLOUD-PROVIDER-PRODUCT/prodcut/get/";
Product product = restTemplate.exchange(PRODUCT_GET_URL + id,HttpMethod.GET,new HttpEntity<Object>(httpHeaders), Product.class).getBody();
这样restTemplate在使用过程中会根据从注册中心拉取的服务列表,默认以轮询算法来访问具体服务(通过服务名)提供者ip
不想使用默认轮询?
@Bean
public IRule iRule(){
return new RandomRule();
}
将IRule配置到配置类中,就可以实现随机访问服务提供端,这样使用的负载算法是全局的!
想针对不同服务设置不同负载均衡算法?
不要让boot项目扫描到配置类
@Configuration
public class RibbonConfig {
@Bean
public IRule iRule(){
return new RandomRule();
}
}
然后在启动类设置不同服务不同负载方式如下,启动类添加下列注解
@RibbonClient(name = "MICROCLOUD-PROVIDER-PRODUCT",configuration = RibbonConfig.class)
三.结尾
针对ribbon其实没什么好说的,实际项目会使用feign,底层使用的也就是ribbon的轮询算法,下一张将会通过日志做具体说明。
想要实际验证的码友可从github直接拉取项目
https://github.com/managerlu/clouddemo