SpringCloud(六):使用Ribbon实现负载均衡

  • 负责均衡客户端,不是服务器端,nginx是在服务器端进行的负载均衡
  • Feign默认集成负载均衡
  • 自动从Eureka Server获取服务列表
  • 使用本地负载均衡策略去请求服务
  • 轮询、随机、一致哈希性、加权、哈希
  • Nginx是c写的,ribbon是java写的,前者性能较好
  • 依赖主要用spring-cloud-starter-netflix-eureka-client
SpringCloud的Ribbon是与Eureka集成的,Ribbon默认会去Eureka中获取服务列表,然后把他缓存下来。当然Ribbon不用Eureka也是可以的,可以自己维护一个服务列表。
 
LoadBalancerClient是负载均衡器的核心类:
 

 IRule的实现类根据不同的算法和逻辑来处理负载均衡的策略:

BaseAvailableRule:选择最小请求数

ClientConfigEnableRoundRobinRule:轮询

RandomRule:随机选择一个Server

WeightedResponseTimeRule:根据weight分配,weight越低,被选择的概率就越小。

posted @ 2019-07-13 14:29  TangXinPing  阅读(352)  评论(0)    收藏  举报