一、服务治理参与者

  • 服务注册中心: eureka-server
  • 服务提供者:HELLO-SERVICE
  • 服务消费者 :HELLO-CONSUMER

很多时候,客户端既是服务提供者又是服务消费者,-》@EnableDiscoveryClient。

服务提供者和服务消费者都是Eureka的客户端,是大部分通信行为的主动发起者。

二、各参与者之间的交互模式

Application-Service --(注册、续约、下线)--》Eureka-Server

Application-Service --(获取registry)--》Eureka-Server

Application-Client --(获取registry)----》Eureka - Server

Application-Client --(本地负载均衡下的远程调用)----》Application - Service

Eureka-Server1 --(复制) --》 Eureka-Server2 --(复制) --》 Eureka-Server3 --(复制) --》  Eureka-ServerN

三、流程描述

1、服务提供者

1.1、服务注册

服务提供者 启动时发送rest请求注册自己到EurekaServer,注册自己的一些元数据。

EurekaServer接收注册内容,放到双层map,第一层的key是服务名,第二层的key是具体服务实例名。

服务提供者:

eureka.client.register-with-eureka=true,默认值为true。否则将不会启动注册操作。

EurekaServer:

1.2、服务同步 - regist

服务注册中心之间因为互相注册为服务。所以,当服务提供者发送注册请求到一个服务注册中心时,它会将请求转发给集群中相连的其他注册中心,从而实现注册中心之间的服务同步。

1.3、服务续约 - renew

注册完服务之后,服务提供者会维持一个心跳用来告诉EurekaServer:我还在,防止EurekaServer的剔除任务将该服务实例从服务列表中排除出去!

2、服务消费者

2.1、获取服务

启动服务消费者时,服务消费者会发送一个请求给 服务注册中心,来获取上面注册的服务清单。

服务注册中心会每隔30秒更新一次服务缓存清单。

2.2、服务调用

服务消费者获得服务清单后,通过服务名可以获得具体提供服务的实例名和实例元数据信息,可以根据需要决定调用哪个实例。

ribbon中默认采用轮询方式进行调用,从而实现客户端的负载均衡。

2.3、服务下线

服务实例关闭,会触发一个服务下线的rest请求给EurekaServer,告诉服务器,我要下线了!

服务端收到下线请求,将该服务实例状态设置为下线,并传播该下线事件。

3、服务注册中心

3.1、失效剔除

服务实例非正常下线,如:内存溢出、网络断开等原因导致服务实例无法正常工作时,服务注册中心无法按期收到“服务下线“消息请求。

EurekaServer会有一个定时任务,默认每隔一段时间(60秒)从当前清单中剔除没有续约(默认90秒)的服务实例。

3.2、自我保护

EurekaServer统计心跳失败比例,如果15分钟内低于85%,则触发自我保护机制:保存当前实例信息,让这些实例不会过期。

三、其他概念

针对区域性故障的容错集群

一个region 对应多个 zone

微服务应用中使用ribbon调用服务时,会优先访问同客户端处于一个zone的服务实例,只有当同一个zone中没有可用的服务实例时才会访问其他zone中的实例。

转载于:https://www.cnblogs.com/lexiaofei/p/7649229.html

SpringCloud的服务注册中心(三) - 进一步了解 Eureka相关推荐

  1. 如何使用 SpringCloud 搭建服务注册中心?

    作者 | 于海东 责编 | 郭   芮 之前在巧玩SpringBoot--SpringBoot的第一个"Hello World!"(https://blog.csdn.net/do ...

  2. SpringCloud 搭建服务注册中心

    SpringCloud 搭建服务注册中心 原创 作者 | 于海东 之前在巧玩SpringBoot--SpringBoot的第一个"Hello World!"(https://blo ...

  3. SpringCloud + Consul服务注册中心 + gateway网关

    1  启动Consul 2  创建springcloud-consul项目及三个子模块 2.1 数据模块consul-producer 2.2 数据消费模块consul-consumer 2.3 ga ...

  4. SpringCloud微服务注册中心如何承载大型系统的千万级访问?源码及原理分析

    2019独角兽企业重金招聘Python工程师标准>>> 问题起源     Spring Cloud架构体系中,Eureka是一个至关重要的组件,它扮演着微服务注册中心的角色,所有的服 ...

  5. 教你一招如何使用几行代码实现zookeeper作为springcloud的服务注册中心

    如果没有安装过zookeeper,请移步 zookeeper的单机安装 - 详细教程:https://blog.csdn.net/Kevinnsm/article/details/116134397 ...

  6. SpringCloud 微服务注册中心 Eureka - Server

    前言 上一篇文章介绍了 Eureka Client 端的相关源码.这篇文章我们学习 Eureka Server 是如何存储 Client 注册过来的实例信息,以及 Server 端如何与 Client ...

  7. SpringCloud常见服务注册中心

  8. 巧玩SpringCloud——使用Eureka搭建服务注册中心与服务发现

    转载请注明出处:http://blog.csdn.net/dongdong9223/article/details/84549747 本文出自[我是干勾鱼的博客] Ingredient: Java:J ...

  9. 使用SpringCloud搭建高可用服务注册中心

    我们需要的,不仅仅是一个服务注册中心而已,而是一个高可用服务注册中心. 上篇博客中我们介绍了如何使用Spring Cloud搭建一个服务注册中心,但是搭建好的服务注册中心是一个单节点的服务注册中心,这 ...

最新文章

  1. 双料状元收割神器来了!清华设立计算机金融双学士学位
  2. struts2 iterator list中对象的list 双层迭代
  3. PB控制性能TreeView
  4. 使用 Nginx 提升网站访问速度
  5. Pycharm如何选择自动打开最近项目
  6. python dlib 年龄 性别_python dlib学习(一):人脸检测
  7. 权限修饰符(public、protected、default、private)权限验证
  8. 【BZOJ4554】游戏(二分图匹配,网络流)
  9. mat格式数据集转换为arff与txt格式
  10. 互联网智商测试:搜索引擎谁的“智商”更高?
  11. IP变更导致fdfs文件上传服务不可用解决流程
  12. 计算机电源改造加大功率,最标准的电脑电源功率计算公式 十代酷睿电源搭配建议...
  13. 比特率,比特,字节的计算
  14. 还在职,入职A签订了竞业限制,如何解除?
  15. 两台电脑共享上网怎么设置?快解析轻松解决共享上网问题
  16. Batch Normalization在CNN中的原理,nb与lrb的区别
  17. 黑群晖折腾记(二)-为不支持通信的UPS 增加断电自动关 NAS
  18. 10张思维导图,全面讲解 Pandas
  19. Linux监控多台远程服务器磁盘空间剩余情况并发送预警邮件以及电话告警
  20. 万字起底澳本聪:一个正在崩溃的谎言

热门文章

  1. HTML入门:html常用的标签
  2. python3导入模块原理_python模块导入原理
  3. mongodb 监控权限_分布式监控系统Zabbix3.4-针对MongoDB性能监控操作笔记
  4. 单元格内多个姓名拆分成一列_把订单按货品拆分成多行
  5. 使用正则表达是搜索多个字符串,表达式中加入变量
  6. Arm发布v9体系架构:Cortex-X2、Cortex-A710和Cortex-A510
  7. 谈谈自己对正则化的一些理解
  8. 轻松理解条件随机场(CRF)
  9. Qt TCP协议 传输简单字符串实例
  10. 毕设tips——conda