Eruke是什么?怎么搭建?


认识Eureka

它是一个基于REST的服务,是实现服务发现与注册的组件。

构成

Eureka采用了C-S的架构,包含了两个组件:Eureka Server与Eureka Client,各个节点启动之后,会在Eureka注册,注册之后只需要使用服务的标识符,就可以访问到服务,而不需要修改服务调用的配置文件。

Eureka架构图

单机构建

项目搭建

  1. 在pom中添加对应的依赖
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

如果没有相关依赖可能是没有添加相关镜像按照如下步骤进行

  1. 找到maven的setting.xml
    pom文件配置地址

  2. 在标签内部添加

<mirror>
    <id>aliyunmaven</id>
    <mirrorOf>*</mirrorOf>
    <name>阿里云公共仓库</name>
    <url>https://maven.aliyun.com/repository/public</url>
</mirror>
  1. 在setter中设置如下参数

-Dmaven.wagon.http.ssl.insecure-true -Dmaven.wagon.http.ssl.allowall-true

配置位置

注册中心

  1. 添加依赖
<!--eureka-server-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
  1. 启动类上添加注解
    @EnableEurekaServer
  2. 配置yml
    这里配置的Eureka需要添加
client:
    register-with-eureka: false    
     # false表示不向注册中心注册自己。
eureka:
  instance:
    hostname: eureka7001.com #eureka服务端的实例名称
  client:
    register-with-eureka: false     #false表示不向注册中心注册自己。
    fetch-registry: false     #false表示自己端就是注册中心,我的职责就是维护服务实例,并不需要去检索服务
    service-url:
      #集群指向其它eureka
      #defaultZone: http://eureka7002.com:7002/eureka/
      #单机就是7001自己
      defaultZone: http://eureka7001.com:7001/eureka/
    #server:
    #关闭自我保护机制,保证不可用服务被及时踢除
    #enable-self-preservation: false
    #eviction-interval-timer-in-ms: 2000

生产者

  1. 添加pom依赖
<!--eureka-client-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
  1. 在启动类上添加下面这个注解
    @EnableEurekaClient
  2. 配置yml
spring:
  application:
  # 需要指定项目所属别名
    name: cloud-payment-service

eureka:
  client:
    #表示是否将自己注册进EurekaServer默认为true。
    register-with-eureka: true
    #是否从EurekaServer抓取已有的注册信息,默认为true。单节点无所谓,集群必须设置为true才能配合ribbon使用负载均衡
    fetchRegistry: true
    service-url:
      #单机版
      defaultZone: http://localhost:7001/eureka
      # 集群版
      #defaultZone: http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka
  instance:
    instance-id: payment8001
    #访问路径可以显示IP地址
    prefer-ip-address: true
    #Eureka客户端向服务端发送心跳的时间间隔,单位为秒(默认是30秒)
    #lease-renewal-interval-in-seconds: 1
    #Eureka服务端在收到最后一次心跳后等待时间上限,单位为秒(默认是90秒),超时将剔除服务
    #lease-expiration-duration-in-seconds: 2

服务发现

  1. 在启动配置中心之后直接访问注册中心所配置的端口,发现无任何信息
    启动成功

  2. 当我们启动生产者之后再在Eureka中刷新,这个时候配置的生产者就出现在了这个页面。
    注册信息到这里我们就使用了Eureka做了一个简单的服务注册。

  3. 集群搭建
    相互注册,相互守望
    搭建一个Eureka集群需要准备至少两个Eureka节点,而搭建集群的环境主要在yml配置这里。

  • 节点一:
server:
  port: 7001

eureka:
  instance:
    hostname: eureka7001.com #eureka服务端的实例名称
  client:
    register-with-eureka: false     #false表示不向注册中心注册自己。
    fetch-registry: false     #false表示自己端就是注册中心,我的职责就是维护服务实例,并不需要去检索服务
    service-url:
      #集群指向其它eureka
      defaultZone: http://eureka7002.com:7002/eureka
  • 节点二:
server:
  port: 7002

eureka:
  instance:
    hostname: eureka7002.com #eureka服务端的实例名称
  client:
    register-with-eureka: false     #false表示不向注册中心注册自己。
    fetch-registry: false     #false表示自己端就是注册中心,我的职责就是维护服务实例,并不需要去检索服务
    service-url:
    #集群指向其它eureka
      defaultZone: http://eureka7001.com:7001/eureka

先启动服务注册中,在启动节点的时候就会注册到里面。

自我保护

当出现如下的提示信息即说明Eruke启动了自我保护
自我保护

什么是自我保护?

当服务出现宕机之后,不会立刻从Eruke中剔除。

为什么会有自我保护?

为了保证Eureka的高可用

当EurekaClient可以正常运行,但是与EurekaServer网络不通畅,EurekaServer就不会立刻将EurekaClient服务剔除(默认90秒)

好死不如赖活着

关闭

修改配置文件

eureka
  server:
    #关闭自我保护机制,保证不可用服务被及时踢除
    enable-self-preservation: false
    eviction-interval-timer-in-ms: 2000

结果演示

关闭演示

停更

停更说明

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

远归的雁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值