Eureka 服务注册中心的搭建

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)
  1. eureka.client.serviceUrl.defaultZone 配置地址不以 localhost 地址来配置,应该按照文中示例配置。
  2. 没有开启相互注册
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.client.register-with-eureka=true
#表示是否将自己注册到 Eureka Server,默认为 true
eureka.client.fetch-registry=true
  1. 没有配置 host 信息
  • Eureka 的 UNKNOWN 问题
    注册中心(Eureka Server)中的服务状态,常见的有 UP、DOWN,但有时会出现另外一种 UNKNOWN 状态,或者 UNKNOWN 服务名。
    UNKNOWN 服务名,是因为在项目中没有配置应用实例的名称导致,配置参数为
    spring.application.name或者eureka.instance.appname ,如果这两个参数都不配置,则将会出现 UNKNOWN 服务名

猜你喜欢

转载自blog.csdn.net/ko0491/article/details/92789063
今日推荐