热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

springCloud服务如何注册Eureka

本篇内容主要讲解“springCloud服务如何注册Eureka”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“spri

本篇内容主要讲解“springCloud服务如何注册Eureka”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“springCloud服务如何注册Eureka”吧!

介绍

 Eureka 是Netfix开发的,一个基于Rest服务的,服务注册与发现的组件。

   主要包括两个组件:Eureka Server和Eureka Client

       Eureka Server:注册中心,提供服务注册与发现

       Eureka Client:java客户端(通常就是微服务中的客户端和服务端) 

springCloud服务如何注册Eureka

上图简要描述了Eureka的基本架构,由3个角色组成:

1.Eureka Server(注册中心,相当于中介)

 2.Service Provider(服务提供方,相当于房东)

 3.Service Consumer(服务消费方,相当于租客)

服务注册Register

  当eureka提供方(provider)向Eureka Server注册时,它提供自身的元数据,例如:ip地址,端口,运行状况指示符等(房东在中介登记房屋信息,比如:面积,价格,地段)

服务续约Renew

  服务提供方(provider)每隔30s(默认)发送一次心跳来续约,通过续约告诉Eureka Server 该服务提供方仍然存在,没有出现问题,正常情况下,如果Eureka Server在90s内没有收到服务提供方的续约,它会将实例从注册中心删除(房东定期告诉中介,我的房子还外租(续约),中介就会保留房屋信息)

springCloud服务如何注册Eureka

服务剔除Eriction

  在默认情况下,当服务提供方连续90s没有向注册中心进行续约,即心跳,注册中心会将该服务从服务注册列表中剔除(房东定期联系中介告诉他房子还续约,如果中介长时间没有收到房东的续约信息,中介会将他的房屋信息下架)

获取注册列表信息FetchRegistries

  服务消费方从注册中心获取注册表信息,并将其缓存到本地,消费方会使用该信息查找其他服务,从而进行远程调用,该注册列表定期30S更新一次,每次返回注册列表信息可能与服务消费方缓存信息不同,服务消费方会自动处理,重新获取整个注册表信息,eureka Server和Eureka Client可以使用JSON/XMl格式进行通信,默认情况下Eureka Client使用Json格式来获取注册列表信息(租客去中介获取所有的房屋信息,而且租客为了获取最新的房屋 信息会定期向中介获取并更新本地列表)

获取服务是服务消费者的基础,所以必有两个重要参数需要注意:

springCloud服务如何注册Eureka

服务下线Cancel

 服务提供方在程序关闭时向注册中心发送取消请求,发送后该服务提供方的信息将从注册中心的服务列表中删除(房东告诉中介房子不租了,中介将此房子的信息删除),该下线请求不会自动完成,需要调用:

springCloud服务如何注册Eureka

远程调用Remote Call

  当服务消费方从注册中心获取到服务提供方信息后,就可以通过Http请求调用对应的服务;服务提供者有多个时,服务消费方会通过Ribbon自动进行负载均衡

自我保护机制

  默认情况下,如果注册中心在90秒内没有接受到某个微服务实例的心跳,会注销该实例,但是在微服务架构下服务之间通常都是跨进程调用,我那果洛通信往往会面临这各种问题,比如微服务状态正常,网络分区故障,导致实例被注销。大量实例被注销,会威胁到整个微服务架构的可用性,所以eureka就有了自我保护机制,Eureka Server 在运行期间会去统计心跳失败比例在 15 分钟之内是否低于 85%,如果低于 85%,Eureka Server 即会进入自我保护机制

Eureka Server 触发自我保护机制后,页面会出现提示:

springCloud服务如何注册Eureka

Eureka Server 进入自我保护机制,会出现以下几种情况:

  1.Eureka不再从注册列表中移除因为长时间没收到心跳而应该过期的服务

  2.Eureka仍然能够接受新服务的注册和查询请求,但是不会被同步到其他节点上

  3.当网络稳定时,当前实例新的注册信息会被同步到其他节点上

  Eureka 自我保护机制是为了防止误杀服务而提供的一个机制。当个别客户端出现心跳失联时,则认为是客户端的问题,剔除掉客户端;当 Eureka 捕获到大量的心跳失败时,则认为可能是网络问题,进入自我保护机制;当客户端心跳恢复时,Eureka 会自动退出自我保护机制。

  如果在保护期内刚好这个服务提供者非正常下线了,此时服务消费者就会拿到一个无效的服务实例,即会调用失败。对于这个问题需要服务消费者端要有一些容错机制,如重试,断路器等。

通过在 Eureka Server 配置如下参数,开启或者关闭保护机制,生产环境建议打开:

springCloud服务如何注册Eureka

到此,相信大家对“springCloud服务如何注册Eureka”有了更深的了解,不妨来实际操作一番吧!这里是编程笔记网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


推荐阅读
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • t-io 2.0.0发布-法网天眼第一版的回顾和更新说明
    本文回顾了t-io 1.x版本的工程结构和性能数据,并介绍了t-io在码云上的成绩和用户反馈。同时,还提到了@openSeLi同学发布的t-io 30W长连接并发压力测试报告。最后,详细介绍了t-io 2.0.0版本的更新内容,包括更简洁的使用方式和内置的httpsession功能。 ... [详细]
  • 在重复造轮子的情况下用ProxyServlet反向代理来减少工作量
    像不少公司内部不同团队都会自己研发自己工具产品,当各个产品逐渐成熟,到达了一定的发展瓶颈,同时每个产品都有着自己的入口,用户 ... [详细]
  • flowable工作流 流程变量_信也科技工作流平台的技术实践
    1背景随着公司业务发展及内部业务流程诉求的增长,目前信息化系统不能够很好满足期望,主要体现如下:目前OA流程引擎无法满足企业特定业务流程需求,且移动端体 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 本文讨论了如何在codeigniter中识别来自angularjs的请求,并提供了两种方法的代码示例。作者尝试了$this->input->is_ajax_request()和自定义函数is_ajax(),但都没有成功。最后,作者展示了一个ajax请求的示例代码。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • 深入理解Kafka服务端请求队列中请求的处理
    本文深入分析了Kafka服务端请求队列中请求的处理过程,详细介绍了请求的封装和放入请求队列的过程,以及处理请求的线程池的创建和容量设置。通过场景分析、图示说明和源码分析,帮助读者更好地理解Kafka服务端的工作原理。 ... [详细]
author-avatar
我爱技术交流
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有