Spring Cloud 2.0 Eureka 搭建

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

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

SpringBoot 项目结构

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服务地址,以英文格式逗号【,】作为分隔符

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值