总括:
ribbon的使用也是类似zuul一样是个入口,经过这个入口的才会有后面的路由,负载
自定义的ribbon只能指定某一个微服用这个自定义的负载,或者应用于所有经过这个项目访问的微服务(放在componentscan扫描范围内,由于框架内部都是
@beanonconditionmiss--这个就是外部只要用自定义的同名的就会用自定义的)
需要指定这个系统中访问某一个服务才用自定义策略的时候,这个自定义的不可在主类全局的扫描范围之内
1,用exlucde: 基于路径的定位排除,或者基于注解的定位排除--------------------java中类似的定位1,用类路径,2,用注解---类似切面,这里用注解定位排除 ---自定义注解的用处就在于定位,标记
2,自定义的ribbon类在@feignCLient中用属性配置即可
一、编写一个注解ExcludeFromComponentScan.java
package com.itmuch.cloud;
public @interface ExcludeFromComponentScan {
}
二 、编写一个TestConfiguration.java,将负载均衡策略变为随机
package com.itmuch.cloud;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import com.netflix.client.config.IClientConfig;
import com.netflix.loadbalancer.IRule;
import com.netflix.loadbalancer.RandomRule;
@Configuration
@ExcludeFromComponentScan
public class TestConfiguration {
@Autowired
IClientConfig config;
@Bean
public IRule ribbonRule(IClientConfig config){
return new RandomRule();
}
}
public class TestConfiguration {
@Autowired
IClientConfig config;
@Bean
public IRule ribbonRule(IClientConfig config){
return new RandomRule();
}
}
三、修改启动类ConsumerMovieRibbonApplication.java
在类上添加两个注解:
@RibbonClient(name="microservice-provider-user",configuration = TestConfiguration.class)
@ComponentScan(excludeFilters={@ComponentScan.Filter(type=FilterType.ANNOTATION,value=ExcludeFromComponentScan.class)})
四、在Controller中添加测试代码:
@Autowired
private LoadBalancerClient LoadBalancerClient;
@GetMapping("/test")
public String test() {
ServiceInstance serviceInstance = this.LoadBalancerClient.choose("microservice-provider-user");
System.out.println("111"+serviceInstance.getHost()+":"+serviceInstance.getPort()+":"+serviceInstance.getServiceId());
ServiceInstance serviceInstance2 = this.LoadBalancerClient.choose("microservice-provider-user2");
System.out.println("222"+serviceInstance2.getHost()+":"+serviceInstance2.getPort()+":"+serviceInstance2.getServiceId());
return "1";
}
五、启动
先启动eureka,再启动四个提供者实例,7900,7901,7902(user2),7903(user2),修改application.yml即可。最后启动消费者。启动成功界面:
六、访问页面:localhost:8010/test,刷新八次。
小结
到这里,自定义配置的展示就完成了。其中的知识点总结一下。
1、扫描包的排除:
@Configuration这个注解是不能@SpringBootApplication的所在扫描到的,否则将自定义的配置将失效。所以需要将TestConfiguration.java排除在包扫描之外,用自定义的注解@ExcludeFromComponentScan,然后在启动类加注解@ComponentScan(excludeFilters{@ComponentScan.Filter(type=FilterType.ANNOTATION,value=ExcludeFromComponentScan.class)})将其排除。
2、自定义负载均衡策略的更换。
@Bean
public IRule ribbonRule(IClientConfig config){
return new RandomRule();
}
这里是关键,还可以换成其它负载均衡策略。
相关推荐
融合到微服务的一些基础设施(如Feign),不需要独立部署Ribbon会将微服务之间的Rest请求转为客户端的负载均衡的RPC调用Ribbon默认的负载均衡策略是轮询,但不止轮询一种,可以自定义配置 1:微服务之间通过Feign调用...
Spring Cloud是构建微服务架构的一套工具集,其中Ribbon是它提供的一个客户端负载均衡器,可以帮助我们实现服务间的智能路由。本篇文章将详细探讨如何在Spring Cloud中使用Ribbon实现负载均衡。 首先,我们要理解...
- **应用配置**:在Spring Cloud应用中,需要配置服务ID,Ribbon会根据该ID从Eureka获取服务实例。 - **自定义负载策略**:可以通过实现IRule接口,定义自己的负载策略,如基于权重的分配。 4. **使用Ribbon进行...
在Spring Cloud框架中,"springcloud-ribbon-feign-hystrix-zuul-config"这个标题涉及到四个关键组件:Ribbon、Feign、Hystrix和Zuul,以及配置管理Config。这些组件都是构建分布式系统时常用的服务发现、客户端负载...
在Spring Cloud生态中,Ribbon是一个重要的客户端负载均衡器,它与Netflix的Eureka服务注册中心结合,使得微服务间的调用能够实现智能路由和负载均衡。本篇将深入探讨Spring Cloud Ribbon的工作原理、功能特性以及...
3. **自定义配置**:用户可以通过自定义实现IRule接口来定制自己的负载均衡策略,以满足特定场景下的需求。 接下来,Feign是另一个Spring Cloud引入的声明式HTTP客户端,它通过基于注解的接口简化了服务间的调用。...
31.硅谷学习_SpringCloud_Ribbon配置初步 32.硅谷学习_SpringCloud_Ribbon负载均衡 33.硅谷学习_SpringCloud_Ribbon核心组件IRule 34.硅谷学习_SpringCloud_自定义Ribbo的负载均衡策略(上) 35.硅谷学习_Spring...
在Spring Cloud生态系统中,Ribbon是一个重要的组件,它主要用于客户端负载均衡。Ribbon是一个轻量级的客户端负载均衡器,它作为一个库内嵌在Netflix的客户端应用中,用于从一组服务器列表中选择一个服务器来执行...
Spring Cloud Ribbon是基于Netflix Ribbon实现的一套客户端 负载均衡的工具。 简单的说,Ribbon是Netflix发布的开源项目,主要功能是提供客户端的软件负载均衡算法,将Netflix的中间层服务连接在一。Ribbon客户端...
2. 深入理解Zuul或Spring Cloud Gateway的路由规则配置,学习如何自定义过滤器,实现API权限控制。 3. 研究Hystrix Dashboard和Turbine,了解服务性能监控和熔断效果的可视化展示。 五、进阶主题 1. Spring Cloud ...
在提供的压缩包文件"springcloud-idea-chapter03-demo1-c1"中,可能包含了实现以上步骤的一个简单示例项目。该项目可能包括了服务提供者和服务消费者两个部分,展示了如何配置Ribbon以及如何在代码中发起负载均衡的...
在Spring Cloud生态系统中,Spring Cloud Ribbon是一个至关重要的组件,它主要负责实现客户端的负载均衡,以确保服务间的调用能够均匀地分散到各个实例上,从而提高系统的整体可用性和性能。Ribbon是Netflix开发的一...
2. 在Spring配置类中,创建一个Bean,注入`IRestTemplate`接口的实现,Spring Cloud会自动注入一个带有Ribbon负载均衡功能的RestTemplate实例: ```java @Configuration public class RestTemplateConfig { @...
3. **Spring Cloud Config Server**:为了更好地管理和维护多数据源的配置,我们可以结合Spring Cloud Config Server,将配置集中存储并管理。这样,当需要更新数据库配置时,只需更改Config Server上的配置,服务端...
总的来说,SpringCloud 通过 Ribbon 和 OpenFeign 提供了灵活的客户端负载均衡解决方案,可以根据不同的场景和需求选择合适的工具和策略。无论是自定义负载均衡规则还是利用默认策略,都能帮助开发者有效地管理和...
在SpringCloud的学习中,首先需要了解的是SpringCloud的基础概念,包括它为何而生,以及它如何解决在分布式系统中常见的问题,如服务发现、负载均衡、断路器模式、配置中心等。SpringCloud基于Spring Boot的轻量级...
CustomizingtheMessageBroker: 消息代理的自定义配置。 9.7. TracingBusEvents: 追踪总线事件。 9.8. BroadcastingYourOwnEvents: 如何广播自定义事件。 9.9. Configurationproperties: 配置属性。 10. ...