1. 搭建与配置 Eureka 服务注册中心
第一步: 创建SpringBoot项目,并且添加相关依赖
第二步: 添加eureka的依赖
<!--Spring Cloud 的 eureka-server 起步依赖-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
第三步: 在 Spring Boot 的入口类上添加一@EnableEurekaServer 注解,用于开启 Eureka 注册中心服务端
第四步: 在 application.properties 文件中配置 Eureka 服务注册中心信息
内嵌定时tomcat的端口
server.port=8761
#设置该服务注册中心的hostname
eureka.instance.hostname=localhost
#由于我们目前创建的应用是一个服务注册中心,而不是普通的应用,默认情况下,这个应用会向注册中心(也是它自己)注册它自己,设置为false表示禁止这种自己向自己注册的默认行为
eureka.client.register-with-eureka=false
#表示不去从服务端检索其他服务信息,因为自己就是服务端,服务注册中心本身的职责就是维护服务实例,它不需要去检索其他服务
eureka.client.fetch-registry=false
#指定服务注册中心的位置
eureka.client.service-url.defaultZone=http://localhost:8761/eureka
2. 启动与测试 Eureka 服务注册中心
第一步: 完成上面的项目搭建后,我们就可以启动 SpringBoot 程序,main 方法运行。(也就是启动类运行)
第二步: 启动成功之后,通过在浏览器地址栏访问我们的注册中心。
3. 向 Eureka 服务注册中心注册服务
我们前面搭建了服务提供者项目,接下来我们就可以将该服务提供者注册到 Eureke 注册中心,步骤如下:
第一步: 在该服务提供者中添加 eureka 的依赖,因为服务提供者向注册中心注册服 务,需要连接 eureka,所以需要 eureka 客户端的支持。
<!--spring-cloud-starter-netflix-eureka-client-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
第二步: 激活 Eureka 中的 EnableEurekaClient 功能:在 Spring Boot 的入口函数处,通过添加@EnableEurekaClient 注解来表明自己是一个 eureka 客户端,让我的服务提供者可以连接 eureka 注册中心。
第三步: 配置服务名称和注册中心地址
#每间隔2s,向服务端发送一次心跳,证明自己依然"存活"
eureka.instance.lease-renewal-interval-in-seconds=2
#告诉服务端,如果我10s之内没有给你发心跳,就代表我故障了,将我踢出掉
eureka.instance.lease-expiration-duration-in-seconds=10
#告诉服务端,服务实例以IP作为链接,而不是取机器名
eureka.instance.prefer-ip-address=true
#告诉服务端,服务实例的名字
eureka.instance.instance-id=34-springcloud-service-goods
#eureka注册中心的连接地址
eureka.client.service-url.defaultZone=http://localhost:8761/eureka
第四步: 启动服务提供者 SpringBoot 程序的 main 方法运行。 (springboot的启动类)
第五步: 启动运行之后,通过在浏览器地址栏访问我们之前搭建好的 eureka 注册中心,就可以看到有一个服务已经注册成功了。
4. 从 Eureka 服务注册中心发现与消费服务
服务的发现由 eureka 客户端实现,而服务的消费由 Ribbon (负载均衡) 实现,也就是说服务的调用需要 eureka 客户端和 Ribbon(负载均衡),两者配合起来才能实现。
Eureka 客户端是一个 Java 客户端,用来连接 Eureka 服务端,与服务端进行交互、负载均衡,服务的故障切换等。
Ribbon 是一个基于 HTTP 和 TCP 的客户端负载均衡器,当使用 Ribbon 对服务进行访问的时候,它会扩展 Eureka 客户端的服务发现功能,实现从Eureka 注册中心中获取服务端列表,并通过 Eureka 客户端来确定服务端是否己经启动。
Ribbon 在 Eureka 客户端服务发现的基础上,实现了对服务实例的选择策略, 从而实现对服务的负载均衡消费。
接下来我们来让服务消费者去消费服务:
我们前面搭建了服务消费者项目,接下来我们就可以使用该服务消费者通过注册 中心去调用服务提供者,步骤如下:
第一步: 在该消费者项目中添加 eureka 的依赖,因为服务消费者从注册中心获取服 务,需要连接 eureka,所以需要 eureka 客户端的支持。
<!--spring-cloud-starter-netflix-eureka-client-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
第二步: 激活 Eureka 中的 EnableEurekaClient 功能: 在 Spring Boot 的入口函数处,通过添加@EnableEurekaClient 注解来表明自己是一个 eureka 客户端,让我的服务消费者可以使用 eureka 注册中心.
第三步: 配置服务的名称和注册中心的地址:
spring.application.name=34-springcloud-service-portal
eureka.client.service-url.defaultZone=http://localhost:8761/eureka
第四步: 前面我介绍了服务的发现由 eureka 客户端实现,而服务的真正调用由 ribbon实现,所以我们需要在调用服务提供者时使用 ribbon 来调用:
@LoadBalanced//使用Ribbon实现负载均衡的调用
@Bean
public RestTemplate restTemplate() {
return new RestTemplate();
}
加入了 ribbon 的支持,那么在调用时,即可改为使用服务名称来访问:
//这个地址是服务端名称
restTemplate.getForEntity("http://34-SPRINGCLOUD-SERVICE-GOODS/service/goods", String.class).getBody();
第五步: 完成上面的步骤后,我们就可以启动消费者的 SpringBoot 程序,main 方法运行。
第六步: 启动成功之后,通过在浏览器地址栏访问我们的消费者,看是否可以正常调用远程服务提供者提供的服务。