本文共 1073 字,大约阅读时间需要 3 分钟。
继上两篇接着说我们将服务注册到Eureka注册中心后,那么服务之间的调用是怎么完成的?
我们的消费者想要去注册中心上消费我们的服务这里就需要使用到springcloud 的组件ribbon 。
Ribbon是一个基于HTTP和TCP的客户端负载均衡器。当使用Ribbon对服务进行访问的时候,它会实现从Eureka注册中心中获取服务端列表,并通过Eureka客户端来确定服务端已经启动。Ribbon在Eureka客户端服务发现的基础上,实现了对服务实例的选择策略,因此Ribbon也是实现负载均衡的策略的。
org.springframework.cloud spring-cloud-starter-netflix-eureka-client
在 Spring Boot 的入口函数处,通过添加@EnableEurekaClient 注解来表明自己是一个 eureka 客户端,让我的服务消费者可以使用 eureka 注册中心;
spring.application.name=03-springcloud-web-consumereureka.client.service-url.defaultZone=http://localhost:8761/eureka
@loadBalance 该注册就是Ribbon的核心,Springcloud对Ribbon实现的封装,让我们开发变得非常的方便,我们在项目中一般会见一个配置类,例如:
@LoadBalanced@Beanpublic RestTemplate restTemplate () { return new RestTemplate();}
那么我们可以说我们新建了一个RestTemplate模板对象,交由spring来管理,我们需要调用微服务的时候就可以使用该模板对象来调用了。例如
需要注意的时:加入了Ribbon的支持,在调用服务的过程中,就是使用服务的名称来调用。restTemplate.getForEntity("http://01-SPRINGCLOUD-SERVICE-PROVIDER/cloud/hello", String.class).getBody();
转载地址:http://wnunz.baihongyu.com/