- 负责均衡客户端,不是服务器端,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越低,被选择的概率就越小。