欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Spring Cloud 2.0 Eureka 搭建

程序员文章站 2022-04-24 08:13:29
...

在 Spring Cloud Finchley 版本中,使用的是 Eureka 1.9 版本,而Eureka 2.0 开源工作宣告停止,暂时对 Spring 2.0 还没有影响,或是可以选择 Consul 等相关组件代替。

首先,我们搭建基础的 Spring Boot 类型项目,项目结构如下:

Spring Cloud 2.0 Eureka 搭建

Spring Boot 已经帮我们做了很多工作,构建Eureka 服务 只需要编写 main启动类,引入相关的pom依赖,以及相关配置参数;

Spring Eureka 2.0 使用的是Eureka 1.9 版本,配置参数上与1.0版本没有变化,唯一需要注意的地方就是 eureka 的artifactId由 spring-cloud-starter-eureka-server变为 spring-cloud-starter-netflix-eureka-server。

首先构建main启动类:

package nut.basicstack.discovery;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;

@SpringBootApplication
@EnableEurekaServer
public class EurekaDiscoveryServer {
    public static void main(String[] args) {
        SpringApplication.run(EurekaDiscoveryServer.class, args);
    }
}

然后配置pom.xml文件:

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
    </properties>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.1.RELEASE</version>
    </parent>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Finchley.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

最后配置application.yml配置文件

server:
  port: 8091
  name: eureka-one
spring:
  application:
    name: ${server.name}
eureka:
  client:
    # 表示是否注册自身到eureka服务器
    register-with-eureka: true
    # 是否从eureka上获取注册信息
    fetch-registry: false
    service-url:
    # 
      defaultZone: http://localhost:${server.port}/eureka/

这里需要说明的是:Eureka 部署分为单机模式,和集群模式,在配置时主要区别是:

单机模式:

register-with-eureka,fetch-registry 一般都配置为false

service-url:defaultZone 配置为自身的eureka服务地址

单机模式:

register-with-eureka,fetch-registry 一般都配置为true

service-url:defaultZone 配置为除自身的eureka服务地址,以英文格式逗号【,】作为分隔符

相关标签: r