9-springcloud-eureka-5-从Eureka服务注册中心发现与消费服务

已经搭建一个服务注册中心,同时也向这个服务注册中心注册了服务,接下来我们就可以发现和消费服务了,这其中服务的发现由 eureka 客户端实现,而服务的消费由 Ribbon 实现,也就是说服务的调用需要 eureka 客户端和 Ribbon,两者配合起来才能实现;

Eureka 客户端是一个 Java 客户端,用来连接 Eureka 服务端,与服务端进行交互、负载均衡,服务的故障切换等;

Ribbon 是一个基于 HTTP 和 TCP 的客户端负载均衡器,当使用 Ribbon 对服务进行访问的时候,它会扩展 Eureka 客户端的服务发现功能,实现从Eureka

注册中心中获取服务端列表,并通过 Eureka 客户端来确定服务端是否己经启动。

Ribbon 在 Eureka 客户端服务发现的基础上,实现了对服务实例的选择策略,

从而实现对服务的负载均衡消费。

接下来我们来让服务消费者去消费服务:

我们前面搭建了服务消费者项目,接下来我们就可以使用该服务消费者通过注册中心去调用服务提供者,步骤如下:

1、在该消费者项目中添加 eureka 的依赖,因为服务消费者从注册中心获取服

务,需要连接 eureka,所以需要 eureka 客户端的支持; demo1-consumer项目中操作

<!--spring-cloud-starter-netflix-eureka-client-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

2、激活 Eureka 中的 EnableEurekaClient 功能:

Spring Boot 的入口函数处,通过添加@EnableEurekaClient 注解来表明自己是一个 eureka 客户端,让我的服务消费者可以使用 eureka 注册中心;

3、配置服务的名称和注册中心的地址:

spring.application.name=34-springcloud-service-portal

eureka.client.service-url.defaultZone=http://localhost:8761/eureka

4、前面我介绍了服务的发现由 eureka 客户端实现,而服务的真正调用由 ribbon实现,所以我们需要在调用服务提供者时使用 ribbon 来调用:

@LoadBalanced//使用Ribbon实现负载均衡的调用--待定ribbon-此步骤没试
@Bean
public RestTemplate restTemplate() {
    return new RestTemplate();
}

加入了 ribbon 的支持,那么在调用时,即可改为使用服务名称来访问:

restTemplate.getForEntity("http://34-SPRINGCLOUD-SERVICE-GOODS/service/goods",

String.class).getBody();

5、完成上面的步骤后,我们就可以启动消费者的 SpringBoot 程序,main 方法运行;

6、启动成功之后,通过在浏览器地址栏访问我们的消费者,看是否可以正常调

用远程服务提供者提供的服务;

 

posted on 2023-04-06 14:01  companion  阅读(12)  评论(0编辑  收藏  举报