Eureka Server:简单搭建和注册微服务

本文详细介绍了如何搭建EurekaServer并实现其高可用性,包括创建微服务项目、配置EurekaServer集群以及将微服务注册到EurekaServer集群上的步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一:简单搭建Eureka Server

  1. 创建一个maven项目
    主要添加了 spring-cloud-starter-netflix-eureka-server倚赖
<?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>
  <groupId>com.itmuch.cloud</groupId>
  <artifactId>microservice-discovery-eureka</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>jar</packaging>

  <!-- 引入spring boot的依赖 -->
  <parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.5.9.RELEASE</version>
  </parent>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <java.version>1.8</java.version>
  </properties>

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

  <!-- 引入spring cloud的依赖 -->
  <dependencyManagement>
    <dependencies>
      <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-dependencies</artifactId>
        <version>Edgware.RELEASE</version>
        <type>pom</type>
        <scope>import</scope>
      </dependency>
    </dependencies>
  </dependencyManagement>

  <!-- 添加spring-boot的maven插件 -->
  <build>
    <plugins>
      <plugin>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-maven-plugin</artifactId>
      </plugin>
    </plugins>
  </build>
</project>

  1. 启动类上需要添加@EnableEurekaServer声明这是一个Eureka Server
  2. application.yml
server:
  port: 8761                    # 指定该Eureka实例的端口
eureka:
  client:
    registerWithEureka: false
    fetchRegistry: false
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/

# 参考文档:http://projects.spring.io/spring-cloud/docs/1.0.3/spring-cloud.html#_standalone_mode
# 参考文档:http://my.oschina.net/buwei/blog/618756
  1. 测试
    启动Eureka Server ,访问http://localhost:8761/ 会出现如下界面,展示了当前ES的服务实例,常用信息,实例信息等.
    在这里插入图片描述

二:将微服务注册到Eureka Server上

  1. 使用上篇中的microservice-simple-provider-user,更改项目名称为microservice-provider-user,添加下面的倚赖
    <dependency>
      <groupId>org.springframework.cloud</groupId>
      <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>
  1. 配置application.yml
server:
  port: 8000
spring:
  application:
    name: microservice-provider-user #指定注册到Eureka Server上的名称
  jpa:
    generate-ddl: false
    show-sql: true
    hibernate:
      ddl-auto: none
  datasource:                           # 指定数据源
    platform: h2                        # 指定数据源类型
    schema: classpath:schema.sql        # 指定h2数据库的建表脚本
    data: classpath:data.sql            # 指定h2数据库的数据脚本
logging:                                # 配置日志级别,让hibernate打印出执行的SQL
  level:
    root: INFO
    org.hibernate: INFO
    org.hibernate.type.descriptor.sql.BasicBinder: TRACE
    org.hibernate.type.descriptor.sql.BasicExtractor: TRACE
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
  instance:
    prefer-ip-address: true  #表示将Ip注册到Eureka上,默认值为false,表示使用主机的host
  1. 同理也可将上篇中的服务消费者项目也注册到Eureka Server中,在次项目名称可定为microservice-consumer-movie
  2. 测试
    启动microservice-discovery-eureka,microservice-provider-usermicroservice-consumer-movie,访问http://localhost:8761/,出现如下
    在这里插入图片描述

三:Eureka Server 的高可用

虽然Eureka Server会缓存数据,但应用中的部分服务挂掉后会造成缓存无法更新,这时就需要构建一个高可用的Eureka集群. 在此将搭建一个双节点的Eureka Server集群.

  1. 复制上文中的项目microservice-discovery-eureka,并将artifactId改成microservice-discovery-eureka-ha
  2. 打开C:\Windows\System32\drivers\etc 下的hosts文件,添加127.0.0.1 peer1 peer2
  3. application.yml,其中使用连字符—将yum分割成三段
spring:
  application:
    name: microservice-discovery-eureka-ha
---
spring:
  profiles: peer1                                 # 指定profile=peer1
server:
  port: 8761
eureka:
  instance:
    hostname: peer1                               # 指定当profile=peer1时,主机名是peer1
  client:
    serviceUrl:
      defaultZone: http://peer2:8762/eureka/      # 将自己注册到peer2这个Eureka上面去

---
spring:
  profiles: peer2
server:
  port: 8762
eureka:
  instance:
    hostname: peer2
  client:
    serviceUrl:
      defaultZone: http://peer1:8761/eureka/
  • 其中第一段未指定Profile,则该段会对所以Profile生效
  • 第二段和第三段配置了项目以Profile1启动时,配置该Eureka Server 的主机名为peer1,并将其注册到http://peer2:8762/eureka/, 而当配置项目以Profile2启动时则相反
    4.将项目打成jar包分别执行 java -jar microservice-discovery-eureka-ha-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer1java -jar microservice-discovery-eureka-ha-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer2,即通过spring.profiles.active来指定使用那个profile启动
  1. 启动后分别访问http://peer1:8761/http://peer2:8762/,会发现有DS Replicas会有另外一个节点
    在这里插入图片描述

四:将应用注册到Eureka Server集群上

以上面的microservice-provider-user项目为例,将配置该为如下即可在这里插入图片描述
也可以只填写一个节点的地址,因为各个节点的数据是互通的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值