微服务-Ribbon负载均衡

文章目录

负载均衡原理

流程

原理

@LoadBalanced

标记RestTemplate发起的http请求要被Ribbon进行拦截和处理

源码分析
  1. ctrl+shift+N搜索LoadBalancerInterceptor,进入。发现实现了ClientHttpRequestInterceptor(客户端Http请求拦截器)的intercept方法

    拦截方法
  2. 打一个断点,启动order-application,浏览器发送请求http://localhost:8080/order/104
  3. 在该方法中对http请求进行拦截,获取到了服务名serviceName = "userservice",然后进入到了RibbonLoadBalancerClient的excute方法中。
  4. 进入到excute方法,发现调用了该类的一个重载方法excute
  5. step into到这个excute方法
    发现serviceId = "userservice",通过serviceId获取到ILoadBalancer,点开ILoadBalancer,发现里面存储了两个userservice,即成功拉取了2个userservice。获取的loadBalancer对象的名称为DynamicServerListLoadBalancer,动态服务列表负载均衡器。
  6. 进入到getServer方法,下一步从loadBalancer的2个userservice中选择1个
    再进入到chooseServer方法里,最终调用了父类的chooseServer方法

    进入,最终调用了rule.choose方法
    查看这个rule,发现是一个IRule类型,这是一个接口,ctrl+h查看实现该接口的类有哪些
    发现有好几种规则,RoundRobin,Random等,正是通过这几种规则从多个userservice中选择出一个合适的userservice。
负载均衡流程

负载均衡策略

通过定义IRule的实现可以修改负载均衡的策略

  1. 方式一,直接在配置类中定义。针对所有微服务而言。
java 复制代码
@Bean
public IRule randomRule(){    
	return new RandomRule();
}
  1. 方式二,在application.yml中定义。针对某个微服务。
yml 复制代码
userservice:  
  ribbon:    
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 负载均衡规则 

饥饿加载

Ribbon默认采用的是懒加载,即第一次访问Ribbon服务的时候才会加载LoadBalanceClient,请求时间会很长;

而饥饿加载在项目启动时加载

yml 复制代码
ribbon:  
  eager-load:    
    enabled: true # 开启饥饿加载     
    clients: userservice # 指定对userservice这个服务饥饿加载
  1. 懒加载,第一次访问是409ms,后续10ms
  2. 饥饿加载,第一次访问是236ms,后续10ms

总结

相关推荐
白泽talk5 小时前
2个小时1w字| React & Golang 全栈微服务实战
前端·后端·微服务
MaCa .BaKa8 小时前
35-疫苗预约管理系统(微服务)
spring boot·redis·微服务·云原生·架构·springcloud
代码拾光14 小时前
微服务之间有哪些调用方式?
微服务·架构设计
南客先生16 小时前
5G融合消息PaaS项目深度解析 - Java架构师面试实战
java·微服务·高并发·paas·分布式系统·缓存策略·5g融合消息
喵叔哟17 小时前
16.【.NET 8 实战--孢子记账--从单体到微服务--转向微服务】--微服务基础工具与技术--Github Action
微服务·github·.net
郝开19 小时前
Nginx 配置参数全解版:Nginx 反向代理与负载均衡;Nginx 配置规范与 Header 透传实践指南;Nginx 配置参数详解
运维·nginx·负载均衡
南客先生20 小时前
Java在云计算、大数据、云原生下的应用和优势 - 面试实战
java·大数据·微服务·云原生·云计算·容器化·分布式计算
uncle_ll20 小时前
FastAPI 零基础入门指南:10 分钟搭建高性能 API
后端·python·微服务·api·fastapi
啥都想学的又啥都不会的研究生1 天前
Kubernetes in action-初相识
java·docker·微服务·容器·kubernetes·etcd·kubelet
编程一生2 天前
微服务相比传统服务的优势
微服务·云原生·架构