当前位置: 首页 > news >正文

微服务中间件--Ribbon负载均衡

Ribbon负载均衡

    • a.Ribbon负载均衡原理
    • b.Ribbon负载均衡策略 (IRule)
    • c.Ribbon的饥饿加载

a.Ribbon负载均衡原理

1.发起请求http://userservice/user/1,Ribbon拦截该请求

2.Ribbon通过EurekaServer拉取userservice

3.EurekaServer返回服务列表给Ribbon做负载均衡

4.Ribbon轮询到端口

在这里插入图片描述

b.Ribbon负载均衡策略 (IRule)

Ribbon的负载均衡规则是一个叫IRule的接口来定义的,每一个子接口都是一种规则:

在这里插入图片描述

在这里插入图片描述

通过定义IRule实现可以修改负载均衡规则,有两种方式:

1.(作用全局)代码方式:在order-service中的OrderApplication类中,定义一个新的IRule:

@Bean
public IRule randomRule(){return new RandomRule();
}

2.(只针对某服务)配置文件方式:在order-service的application.yml文件中,添加新的配置也可以修改规则

userservice:ribbon:NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule #负载均衡规则

c.Ribbon的饥饿加载

Ribbon默认是采用懒加载,即第一次访问时才会去创建LoadBalanceClient,请求时间会很长。而饥饿加载则会在项目启动时创建,降低第一次访问的耗时,通过下面配置开启饥饿加载:

ribbon:eager-load:enabled: true # 开启饥饿加载clients:  # 指定饥饿加载的服务名称- userservice
http://www.lryc.cn/news/132353.html

相关文章:

  • 字符设备驱动实例(ADC驱动)
  • python基础5——正则、数据库操作
  • SpringAOP原理:手写动态代理实现
  • 【旅游度假】Axure酒店在线预订APP原型图 旅游度假子模块原型模板
  • Android JNI系列详解之CMake和ndk-build编译工具介绍
  • 【Linux取经路】解析环境变量,提升系统控制力
  • TCP编程流程(补充)
  • 每天一道leetcode:433. 最小基因变化(图论中等广度优先遍历)
  • 【C++】做一个飞机空战小游戏(十)——子弹击落炮弹、炮弹与飞机相撞
  • 去除UI切图边缘上多余的线条
  • Spring高手之路13——BeanFactoryPostProcessor与BeanDefinitionRegistryPostProcessor解析
  • 【LeetCode动态规划】详解买卖票I~IV,经典dp题型买
  • 【深入探究人工智能】:常见机器学习算法总结
  • 设计模式之解释器模式详解及实例
  • Nodejs沙箱逃逸--总结
  • No115.精选前端面试题,享受每天的挑战和学习
  • Elasticsearch:语义搜索 - Semantic Search in python
  • Flink学习笔记(一)
  • [Raspberry Pi]如何用VNC遠端控制樹莓派(Ubuntu desktop 23.04)?
  • 17.HPA和rancher
  • VS2022远程Linux使用cmake开发c++工程配置方法
  • 《强化学习:原理与Python实战》——可曾听闻RLHF
  • STM32——RTC实时时钟
  • webSocket 开发
  • c#设计模式-结构型模式 之 代理模式
  • openpnp - 自动换刀的设置
  • 《HeadFirst设计模式(第二版)》第十章代码——状态模式
  • day-25 代码随想录算法训练营(19)回溯part02
  • PG逻辑备份与恢复
  • 图数据库_Neo4j和SpringBoot整合使用_实战创建明星关系图谱---Neo4j图数据库工作笔记0010