Eureka 介绍
Eureka 是 Netflix 公司开源的产品,它是一种基于 REST(Representational State Transfer)的服务,主要用于 AWS 云。Eureka 提供了完整的 Service Registry 和 Service Discovery 实现,也是 Spring Cloud 体系中最重要最核心的组件之一。
简单来说 ,Eureka 就是 Netflix 开源的一款提供服务注册和发现的产品,并且提供了 Java 客户端。当然在 Spring Cloud 大力优化后的 Eureka,已经不仅仅只是用于 AWS 云,而是可以应用在任何需要使用注册中心的场景。
Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块,在 Eureka 的基础上优化了一些配置,对一些不太合理的逻辑进行了优化,并提供了可视化界面,方便查看服务的运行状态。
Eureka 由两个组件组成:Eureka 服务端和 Eureka 客户端。Eureka 服务端就是注册中心。Eureka 客户端是一个 java 客户端,用来简化与服务端的交互、作为轮询负载均衡器,并提供服务的故障切换支持。
- Eureka Server,担任注册中心的角色,提供了服务的注册和发现功能
- Service Provider,服务提供者,将自身服务注册到 Eureka Server,同时通过心跳来检查服务的运行状态
- Service Consumer,服务调用者,从 Eureka 获取注册服务列表,找到对应的服务地址再进行调用
搭建Eureka Server
Eureka 是由 Java 语言开发而成,Spring Cloud 使用 Spring Boot 技术对 Eureka 进行了封装。因此它的部署方式非常简单,只需要项目引入 Eureka 对应的 Starter 包
建立Project
父pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<modules>
<module>eureka-server01</module>
<module>eureka-server02</module>
<module>eureka-server03</module>
</modules>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.5.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.ghgcn</groupId>
<artifactId>cloud</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>cloud</name>
<packaging>pom</packaging>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
<!--spring cloud 版本-->
<spring-cloud.version>Greenwich.SR1</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
子模块 pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>cloud</artifactId>
<groupId>com.ghgcn</groupId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>eureka-server01</artifactId>
<dependencies>
<!--注册中心-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
</dependencies>
</project>
启动类
@EnableEurekaServer
注解,开启注册中心服务发现功能。
- application.properties
#项目名称
spring.application.name=eureka serve
#项目端口
server.port=8001
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.instance.hostname=eureka01
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.client.register-with-eureka=true
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.client.fetch-registry=true
集群
在上面 Eureka 单个示例的基础上,复制出三份来分别命名为:eureka01、eureka02、eureka03 ,eureka04三个示例项目,使用这三个示例项目搭建 Eureka Server 的集群。
- eureka01
#项目名称
spring.application.name=eureka serve
#项目端口
server.port=8001
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.instance.hostname=eureka01
#集群
eureka.client.serviceUrl.defaultZone=http://eureka02:8002/eureka,http://eureka03:8003/eureka,http://eureka04:8004/eureka
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.client.register-with-eureka=true
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.client.fetch-registry=true
- eureka02
#项目名称
spring.application.name=eureka serve
#项目端口
server.port=8002
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.instance.hostname=eureka02
#集群
eureka.client.serviceUrl.defaultZone=http://eureka01:8001/eureka,http://eureka03:8003/eureka,http://eureka04:8004/eureka
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.client.register-with-eureka=true
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.client.fetch-registry=true
- eureka03
#项目名称
spring.application.name=eureka serve
#项目端口
server.port=8003
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.instance.hostname=eureka03
#集群
eureka.client.serviceUrl.defaultZone=http://eureka01:8001/eureka,http://eureka02:8002/eureka,http://eureka04:8004/eureka
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.client.register-with-eureka=true
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.client.fetch-registry=true
- eureka04
#项目名称
spring.application.name=eureka serve
#项目端口
server.port=8003
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.instance.hostname=eureka04
#集群
eureka.client.serviceUrl.defaultZone=http://eureka01:8001/eureka,http://eureka02:8002/eureka,http://eureka03:8003/eureka
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.client.register-with-eureka=true
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.client.fetch-registry=true
- hosts文件配置
需要本地配置 host 信息。在 Windows 的
C:\Windows\System32\drivers\etc\hosts
或者 Linux 的/etc/hosts 文件末添加以下信息:
127.0.0.1 eureka01 eureka02 eureka03
10.18.200.132 eureka04
分别启动4个应用
- System Status,主要展示系统状态,比如启动时间等
- DS Replicas,该服务从哪里同步数据
- Instances currently registered with Eureka,注册在 Eureka 的实例列表
- General Info,系统运行环境,比如内存、cpu 等
- Instance Info,本服务的基础信息,比如 ip 地址,状态等
在 General Info 模块中,可以看到 registered-replicas(已经注册到的副本)和 available-replicas(有效副本)都可以看到其它两个注册中心的信息。
- 注册中心副本不可用(unavailable-replicas)
- eureka.client.serviceUrl.defaultZone 配置地址不以 localhost 地址来配置,应该按照文中示例配置。
- 没有开启相互注册
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.client.register-with-eureka=true
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.client.fetch-registry=true
- 没有配置 host 信息
- Eureka 的 UNKNOWN 问题
注册中心(Eureka Server)中的服务状态,常见的有 UP、DOWN,但有时会出现另外一种 UNKNOWN 状态,或者 UNKNOWN 服务名。
UNKNOWN 服务名,是因为在项目中没有配置应用实例的名称导致,配置参数为
spring.application.name或者eureka.instance.appname ,如果这两个参数都不配置,则将会出现 UNKNOWN 服务名