第六章:SpringCloud Ribbon 自定义服务端口访问策略(Rule)

简介: 在使用ribbon的过程中,难免会遇到对不同服务的负载均衡策略不同。我举个例子。A服务开了两个端口B服务开了两个端口如果使用默认配置。ribbon使用的是轮询策略。

在使用ribbon的过程中,难免会遇到对不同服务的负载均衡策略不同。
我举个例子。
A服务开了两个端口
B服务开了两个端口
如果使用默认配置。ribbon使用的是轮询策略。
但是如果业务需要A轮询,B随机。
我们该怎么做呢。(提示:ribbon默认扫描包是启动类所在包下com.fantj.ribbon)

方案一:

  • 写一段配置,扔到该包外面com.fantj下

/**
 * Created by Fant.J.
 * 2017/11/30 18:56
 */
@SuppressWarnings("ALL")
@Configuration
//@RibbonClient(name = "provider-user",configuration = Config.class)
public class Config {
    @Autowired
    IClientConfig clientConfig;
    @Bean
    @ConditionalOnMissingBean
    public IRule ribbonRule(IClientConfig clientConfig) {
        return new RandomRule();   //随机访问策略
    }
}

方案二:

自定义注解,并加载到启动类
自定义注解:

package com.fantj.fantjconsumermovieribbon;

/**
 * Created by Fant.J.
 * 2017/12/1 17:06
 */
public @interface ExcludeFromComponentScan {
}

启动项添加注解@ComponentScan


img_1c74d2e6a6f3563f9619aa793de1a11a.png
image.png

其中
@RibbonClient(name = "provider-user",configuration = Config.class)
这个注解的作用是,告诉ribbon ,provider-user这个服务的策略配置在Config.class类里面。所以我在Config.java里把//@RibbonClient(name = "provider-user",configuration = Config.class)注释掉了。两者作用相同。
最后,在Config.java里添加注解@ExcludeFromComponentScan
重启,便会看到provider-user这个服务端口访问策略是随机,别的服务访问策略是轮询。

方案三

写入配置文件application.yml(ribbon读取配置文件的优先级最高
看下官方的文档:

users:    #这里修改成自己的微服务id
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.WeightedResponseTimeRule  #这里是Rule

修改成自己的

provider-user:  #微服务id
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.WeightedResponseTimeRule  #Rule,这个是权重响应事件Rule
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
相关文章
|
安全 网络协议 网络安全
【Azure APIM】APIM服务配置网络之后出现3443端口不通,Management Endpoint不健康状态
如果没有关联的网络安全组,则阻止所有网络流量通过子网和网络接口。
296 30
|
负载均衡 算法 Java
除了 Ribbon,Spring Cloud 中还有哪些负载均衡组件?
这些负载均衡组件各有特点,在不同的场景和需求下,可以根据项目的具体情况选择合适的负载均衡组件来实现高效、稳定的服务调用。
1226 61
|
网络协议 Java Shell
java spring 项目若依框架启动失败,启动不了服务提示端口8080占用escription: Web server failed to start. Port 8080 was already in use. Action: Identify and stop the process that’s listening on port 8080 or configure this application to listen on another port-优雅草卓伊凡解决方案
java spring 项目若依框架启动失败,启动不了服务提示端口8080占用escription: Web server failed to start. Port 8080 was already in use. Action: Identify and stop the process that’s listening on port 8080 or configure this application to listen on another port-优雅草卓伊凡解决方案
833 7
|
缓存 负载均衡 应用服务中间件
Nginx 实现一个端口代理多个前后端服务
【10月更文挑战第19天】Nginx 的强大功能不仅限于此,它还可以与其他技术和工具相结合,为我们的应用提供更强大的支持和保障。在不断发展的互联网时代,掌握 Nginx 的使用技巧将为我们的工作和生活带来更多的便利和效益。
|
负载均衡 监控 网络协议
SpringCloud之Ribbon使用
通过以上步骤,就可以在Spring Cloud项目中有效地使用Ribbon来实现服务调用的负载均衡,提高系统的可靠性和性能。在实际应用中,根据具体的业务场景和需求选择合适的负载均衡策略,并进行相应的配置和优化,以确保系统的稳定运行。
600 15
|
安全 Linux 网络安全
nmap 是一款强大的开源网络扫描工具,能检测目标的开放端口、服务类型和操作系统等信息
nmap 是一款强大的开源网络扫描工具,能检测目标的开放端口、服务类型和操作系统等信息。本文分三部分介绍 nmap:基本原理、使用方法及技巧、实际应用及案例分析。通过学习 nmap,您可以更好地了解网络拓扑和安全状况,提升网络安全管理和渗透测试能力。
890 5
|
负载均衡 Java Nacos
SpringCloud基础1——远程调用、Eureka,Nacos注册中心、Ribbon负载均衡
微服务介绍、SpringCloud、服务拆分和远程调用、Eureka注册中心、Ribbon负载均衡、Nacos注册中心
SpringCloud基础1——远程调用、Eureka,Nacos注册中心、Ribbon负载均衡
|
SpringCloudAlibaba API 开发者
新版-SpringCloud+SpringCloud Alibaba
新版-SpringCloud+SpringCloud Alibaba
|
11月前
|
负载均衡 Dubbo Java
Spring Cloud Alibaba与Spring Cloud区别和联系?
Spring Cloud Alibaba与Spring Cloud区别和联系?
|
12月前
|
人工智能 SpringCloudAlibaba 自然语言处理
SpringCloud Alibaba AI整合DeepSeek落地AI项目实战
在现代软件开发领域,微服务架构因其灵活性、可扩展性和模块化特性而受到广泛欢迎。微服务架构通过将大型应用程序拆分为多个小型、独立的服务,每个服务运行在其独立的进程中,服务与服务间通过轻量级通信机制(通常是HTTP API)进行通信。这种架构模式有助于提升系统的可维护性、可扩展性和开发效率。
4390 2

热门文章

最新文章