1、简述,什么是Eureka

Eureka是Netflix开源的一款提供服务注册和发现的产品,它提供了完整的Service Registry和Service Discovery实现。也是springcloud体系中最重要最核心的组件之一。

我是简单的理解为注册中心。所有的服务都要来注册中心注册,所有的调用路径都是在注册中心获取

2、开始 Eureka

(1)项目初始化

从零建立一个 Eureka项目(如果你已经有一个初始化的spring boot项目可以直接看第二部,直接选择相关的依赖加进去然后 reimport 下maven就可以了),可以直接访问spring的官方初始化平台 https://start.spring.io/ ,也可以使用idea 上的spring initializr 插件生成,步骤都是一样的。

在写好自己项目的 名称,选择完spring boot 和Java 版本以后选择项目需要的依赖(add dependencies),可以直接搜索Eureka,插件里可以直接选择在分类中选择勾选后确认就可以了。

下边为在idea 上的操作步骤:项目上右键=》new=》module=》Spring initializr ,然后next,出现如下界面,修改指出的内容

然后next去选择依赖(如下图) 最后一路next finish就行了 。

(2)项目概览

以上一番操作以后可以得到一个初始化以后的项目

重要的pom文件如下(如果有一个已经初始化的spring boot项目 直接加入相关的pom 依赖也是可以的)

<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>groupId</groupId>
        <artifactId>spring-cloud-demo</artifactId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <groupId>com.demo</groupId>
    <artifactId>eureka</artifactId>
    <version>0.0.1</version>
    <name>eureka</name>
    <description>注册中心</description>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </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>
</project>

其他文件一会还要修改 在下边看。

(3)修改yml 配置文件

yml文件( 为application.yml,是由application.properties 重命名而来)如下

server:
  port: 3000
eureka:
  server:
    enable-self-preservation: false  #关闭自我保护机制
    eviction-interval-timer-in-ms: 4000 #设置清理间隔(单位:毫秒 默认是60*1000)
  instance:
    hostname: eureka
  client:
    registerWithEureka: false #不把自己作为一个客户端注册到自己身上
    fetchRegistry: false  #不需要从服务端获取注册信息(因为在这里自己就是服务端,而且已经禁用自己注册了)
    serviceUrl:
      defaultZone: http://localhost:${server.port}/eureka/ #eureka server 的地址,单机就写部署的地址

(4)添加启动类注解

在启动类上加入注解@EnableEurekaServer (org.springframework.cloud.netflix.eureka.server.EnableEurekaServer)

这样一个单机版的注册中心基本配置就好了

(5)启动效果

本地启动以后访问 http://localhost:3000 效果如下

这样一个注册中心就完成了;

(6)补充(服务提供者和服务消费者)

到这里一个单机版的注册中心就已经搭建完毕了 ,可是还不能确定这个注册中心的功能是否可用。

所以如果需要验证功能是否完整的话,还需要有服务的提供者和服务的消费者联合测试注册中心的注册和发现功能。

服务提供者开发

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐