快盘下载:好资源、好软件、快快下载吧!

快盘排行|快盘最新

当前位置:首页软件教程安卓软件教程 → SpringCloud中的eureka如何注册

SpringCloud中的eureka如何注册

时间:2020-02-28 10:09:33人气:作者:快盘下载我要评论

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

eureka的架构图如下:

SpringCloud中的eureka如何注册

二、在SpringCloud项目中使用eureka

要想使用SpringCloud的子模块,一般分为两步: 引入相关的maven依赖 然后在配置类上加上@EnableXXX注解

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

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

pom.xml中添加依赖

org.springFramework.cloudspring-cloud-starter-eureka-server

创建启动类,并在启动类上加上@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中

 org.springframework.cloudspring-cloud-starter-eureka

修改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

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

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

相关文章

  • 带你玩转SpringCloud实战

    一篇文章带你玩转SpringCloud实战,包含Spring Cloud Netflix以及Spring Cloud Alibaba所有组件...
  • 这个注册的-IP-网络都不通了,Eureka-注册中心竟然无法踢掉它!

    本文导读:微服务技术架构选型介绍k8s 容器化部署架构方案Eureka 注册中心问题场景问题解决手段及原理剖析阅读本文建议先了解:注册中心基本原理K8s(Kuberneters)基本概念 我们的微服务目前都是在服务器上部署的,也是基于 Docker 来部署的。运维部门基于 K8s 自研了一套容器云管理平台,平台名称叫做 Ares,我们也开始准备将微服务迁移......

网友评论

快盘下载暂未开通留言功能。

关于我们| 广告联络| 联系我们| 网站帮助| 免责声明| 软件发布

Copyright 2019-2029 【快快下载吧】 版权所有 快快下载吧 | 豫ICP备10006759号公安备案:41010502004165

声明: 快快下载吧上的所有软件和资料来源于互联网,仅供学习和研究使用,请测试后自行销毁,如有侵犯你版权的,请来信指出,本站将立即改正。