来源:
使用Eureka
作为服务注册中心,在服务启动后,各个微服务会将自己注册到Eureka server
。那么服务之间是如何调用?又是如何进行负载均衡的呢?
目前,在Spring cloud 中服务之间通过restful方式调用有两种方式
- restTemplate+Ribbon - feign从实践上看,采用feign的方式更优雅(feign内部也使用了ribbon做负载均衡)。
zuul也有负载均衡的功能,它是针对外部请求做负载,那客户端ribbon的负载均衡又是怎么一回事?
客户端ribbon的负载均衡,解决的是服务发起方(在Eureka注册的服务)对被调用的服务的负载,比如我们查询商品服务要调用显示库存和商品明细服务,通过商品服务的接口将两个服务组合,可以减少外部应用的请求,比如手机App发起一次请求即可,可以节省网络带宽,也更省电。
ribbon是对服务之间调用做负载,是服务之间的负载均衡,zuul是可以对外部请求做负载均衡。