SpringCloud之eureka注册中心入门

eureka注册中心

一、基本概念

SpringCloud封装 了Netflix公司的eureka作为自己微服务的注册中心。这个注册中心和dubbo中的zookeeper很相似,简单来说,只要你可以将你的”微服务“模块注册到注册中心,就可以供其他服务调用,一般来说,只有provider会注册到eureka,consumer也可以注册,但是并不建议这么做。

eureka的架构图如下:

二、在SpringCloud项目中使用eureka

  • 要想使用SpringCloud的子模块,一般分为两步:

    1. 引入相关的maven依赖
    2. 然后在配置类上加上@EnableXXX注解

1. 创建一个新的Maven的Module项目,用来开启eureka

? 为了让小伙伴们更好地学习,我将上一次的项目复制了一份(见Github项目代码)

  • pom.xml中添加依赖
<dependency>
   <groupId>org.springframework.cloud</groupId>
    <!--这个是服务端的依赖-->
   <artifactId>spring-cloud-starter-eureka-server</artifactId>
</dependency>   
  • 创建启动类,并在启动类上加上@EnableEurekaServer注解
@SpringBootApplication
@EnableEurekaServer
public class EurekaRegistApp_7001 {
    public static void main(String[] args) {
        SpringApplication.run(EurekaRegistApp_7001.class,args);
    }
}
  • 添加application.yml配置文件如下:
server:
  port: 7001

eureka:
  instance:
    hostname: localhost #eureka服务端的实例名称
  client:
    register-with-eureka: false     #false表示不向注册中心注册自己。
    fetch-registry: false     #false表示自己端就是注册中心,我的职责就是维护服务实例,并不需要去检索服务
    service-url:
#    这两个变量就是上边定义过的
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/       #设置与Eureka Server交互的地址查询服务和注册服务都需要依赖这个地址。
  • 然后启动这个项目,就输入访问地址http://localhost:7001/,就可以查看eureka注册中心了

当有服务注册到这里时,就会在上图中出现。

2. 将服务提供者注册进eureka

  • 将eureka的依赖加入到pom.xml中
 <dependency>
     <groupId>org.springframework.cloud</groupId>
     <artifactId>spring-cloud-starter-eureka</artifactId>
 </dependency>
  • 修改provider项目的application.yml
server:
  port: 8001

spring:
  application:
#  这个应用的名称,用来注册在注册中心的名称
    name: demo2-provider

eureka:
  client: #客户端注册进eureka服务列表内
    service-url:
#    这个地址是在eureka的application.yml中定义过的
      defaultZone: http://localhost:7001/eureka
  instance:
    instance-id: demo2-provider-8001
    prefer-ip-address: true     #访问路径可以显示IP地址
  • 修改启动类,加上@EnableEurekaClient注解,表明这是一个eureka的客户端,用来向eureka注册此服务
@EnableEurekaClient //本服务启动后会自动注册进eureka服务中
@SpringBootApplication
public class Demo1Provider {
    public static void main(String[] args) {
        SpringApplication.run(Demo1Provider.class, args);
    }
}
  • 然后重新启动这个服务提供者项目,就会在注册中心中看到这个服务

三、几个小插曲

  • 如果你的eureka注册中心出现如图情况

请不要惊慌,这只是eureka的自我保护意识。Eureka Server 在运行期间会去统计心跳失败比例在 15 分钟之内是否低于 85%,如果低于 85%,Eureka Server 会将这些实例保护起来,让这些实例不会过期,但是在保护期内如果服务刚好这个服务提供者非正常下线了,此时服务消费者就会拿到一个无效的服务实例,此时会调用失败,对于这个问题需要服务消费者端要有一些容错机制,如重试,断路器等。

我们在单机测试的时候很容易满足心跳失败比例在 15 分钟之内低于 85%,这个时候就会触发 Eureka 的保护机制,一旦开启了保护机制,则服务注册中心维护的服务实例就不是那么准确了,此时我们可以使用eureka.server.enable-self-preservation=false来关闭保护机制,这样可以确保注册中心中不可用的实例被及时的剔除(不推荐)。

  • 如何搭建eureka集群

原理就是多创建几个eureka项目,但是端口不同,然后在注册的时候,将它们写在一起(下期会说到)

本项目代码地址

原文地址:https://www.cnblogs.com/Lyn4ever/p/12359582.html

时间: 2024-07-30 14:49:27

SpringCloud之eureka注册中心入门的相关文章

SpringCloud(一)Eureka注册中心

Eureka简介 Eureka作为注册中心,管理各种服务功能包括服务的注册.发现.熔断.负载.降级等 Eureka注册中心实例 Eureka Server 1.pom文件配置SpringBoot.SpringCloud的依赖: 2.启动类配置 @EnableEurekaServer 注解,表示注册中心: /** * SpringCloud是基于SpringBoot的,这是一个启动类的注解 */ @SpringBootApplication /** * 这是注册中心Eureka的注解 */ @En

【SpringCloud】SpringCloud 之 Eureka注册中心(二)

Eureka简介 Eureka是一项基于REST(代表性状态转移)的服务,主要在AWS云中用于定位服务,以实现负载均衡和中间层服务器的故障转移.我们称此服务为Eureka Server.Eureka还带有一个基于Java的客户端组件Eureka Client,它使与服务的交互更加容易.客户端还具有一个内置的负载均衡器,可以执行基本的循环负载均衡.在Netflix,更复杂的负载均衡器将Eureka包装起来,以基于流量,资源使用,错误条件等多种因素提供加权负载均衡,以提供出色的弹性. Git地址:h

Spring-Cloud之Eureka注册中心环境搭建(单节点)

一 Eureka概述 服务启动时会生成服务的基本信息对象InstanceInfo,然后在启动时会register到服务治理中心. 注册完成后会从服务治理中心拉取所有的服务信息,缓存在本地. 之后服务会被30s(可配置)发送一个心跳信息,续约服务. 如果服务治理中心在90s内没有收到一个服务的续约,就会认为服务已经挂了,会把服务注册信息删掉. 服务停止前,服务会主动发送一个停止请求,服务治理中心会删除这个服务的信息. 如果Eureka Server收到的心跳包不足正常值的85%(可配置)就会进入自

springcloud(二):注册中心Eureka

http://www.ityouknow.com/spring-cloud.html Eureka是Netflix开源的一款提供服务注册和发现的产品,它提供了完整的Service Registry和Service Discovery实现.也是springcloud体系中最重要最核心的组件之一. 背景介绍 服务中心 服务中心又称注册中心,管理各种服务功能包括服务的注册.发现.熔断.负载.降级等,比如dubbo admin后台的各种功能. 有了服务中心调用关系会有什么变化,画几个简图来帮忙理解 项目

SpringCloud学习心得—1.2—Eureka注册中心的密码认证、高可用的设置

SpringCloud学习心得—1.2—Eureka注册中心的密码认证.高可用的设置 这是相关代码 链接 Eureka开启密码配置 添加依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-security</artifactId> </dependency> 向properties添加密码与用户名 spr

Spring-cloud微服务实战【三】:eureka注册中心(中)

??回忆一下,在上一篇文章中,我们创建了两个springboot项目,并且在consumer项目中通过restTemplate进行HTTP通信,成功访问到了producer提供的接口,思考一下这样的实现方式有什么问题? ??1.consumer必须知道producer的IP,才能调用对方的HTTP接口,并且在consumer代码中使用硬编码的方式来访问producer的HTTP接口,代码耦合度高,实现方式不优雅.也许有童鞋会说,我们可以在application.properties配置文件进行配

Spring-cloud微服务实战【四】:eureka注册中心(下)

回忆一下,在上一篇文章中,我们使用eureka作为注册中心,将producer注册到eureka,并且在consumer中通过eureka发现producer服务进行调用,让我们来分析一下,这样是否已经足够完美,还有没有什么问题? 1.首先,eureka没有任何安全验证,任何应用都可以访问,这显然不安全,因此eureka也需要使用spring-security配置用户密码验证. 2.其次,所有服务注册和发现都需要通过eureka,而我们的eureka目前是单机运行,这就有可能导致单点问题,一旦e

SpringCloud Eureka(注册中心集群)

多个注册中心,其实用不同的配置对应 不同的端口号注册就行了. 注册中心自己也是个服务,看看之前的单个注册中心是怎么样的呢? server: port: 8888 # 服务端口eureka: instance: hostname: localhost # 设置主机名 client: registerWithEureka: false # 是否向 Eureka 注册服务.该应用为服务注册中心,不需要自注册,设置为 false fetchRegistry: false # 是否检索服务.该应用为服务注

springCloud Eureka注册中心原理及配置理解

Eureka 配置流程 原理:     服务提供方启动后将注册到 注册中心,提供IP, 名字,什么服务等信息, 服务调用方作为客户端注册到注册中心后,拉取注册中心的服务列表,在通过负载均衡调用对应的服务提供方. 注册中心可以建立集群,生成多台eureka,注册中心为了监测各个服务的心跳,将在每30S 向所注册的服务发起请求判断 服务是否挂掉,如果挂掉90S后将会将服务从注册中心剔除. 一个服务可以监测多台服务实例,从而可实现均很负载. 配置步骤:  一.加依赖 以下指POM文件 <!--注册中心