![](https://img.kancloud.cn/2c/f8/2cf83899738f4903a5b1a46edd3fd666_1101x512.png)
EurekaServer启动,等待客户端前来注册.
EurekaServer之间通过Replicat完成服务列表同步.每个Eureka节点,都会存储完整的服务列表.
EurekaClient会通过配置中的defaultZone信息前往EurekaServer去进行注册.
心跳机制:微服务客户端每隔30s(默认值)回向Server发送一次"心跳".报告状态.如果超过90s(默认值)
没有接收到心跳,会标注该服务失效,并从服务列表删除.
自我保护机制:在单位时间内,如果没有收到超过85%的Client发送过来的心跳,那么会判断为服务器
自己网络出现异常.从而进入保护模式.不再删除服务列表中的微服务.直到心跳请求恢复之
后,Eureka会退出保护模式.
EurekaClient会定时全量或者增量从EurekaServer拉取服务列表.并将完整的服务列表缓存到本地.
即使所有server都不能使用,客户端仍然能够使用缓存的服务列表完成远程调用.
EurekaClient通过服务列表获取调用信息,完成服务调用.
**Eureka设计**
分布式系统的CAP理论.
C:一致性.从各个节点获得的数据一致.
A:可用性.每一次请求都会得到一个(正确)响应.
P:分区容忍.节点之间出现网络分区.系统仍然能够继续运行.
分布式系统在设计时,只能倾向于CAP中的两个,不可能3个同时兼顾.
DUBBO的设计倾向于哪两个?
dubbo的设计倾向于CP. dubbo更注重一致性.每次服务列表同步都是由leader发起,确保每个节点都写入
成功,才会确认写入.保证了每个节点的一致性.
leader不可用时,会选举新的leader.而在选举期间.集群是不可用的.直到leader选举结束,并完成同步.才能
继续提供服务.所以DUBBO的设计更倾向于数据的一致性.
Eureka的设计倾向于哪两个?
eureka的设计倾向于AP.首先,Eureka服务器之间的同步属于异步的P2P方式.有可能在同一时间不同
Server节点,拉取到不同的服务列表的.但是放心,最终一致性还是可以保障的.Server节点都是平等的,没有
主从概念.任何一个Server挂掉.客户端会自动连接到其他存活Server提供服务.即使所有Server都挂掉.客
户端也会从本地缓存的服务列表继续获得信息.由此可以得出结论.Eureka是更倾向于可用性的设计
- mybatis
- 基础
- maven依赖
- 主配置文件
- 实体映射表
- Mapper接口
- xxxMapper.xml
- 代码测试
- CURD
- 查询操作
- 新增操作
- 修改操作
- 删除操作
- 生命周期&作用域
- 实体类型配置别名
- 进阶查询
- 列名与属性名不对应
- 多条件sql查询
- 模糊查询
- 获取保存后的主键
- 动态sql
- where配合If
- where配合choose
- where配合foreach
- Sql片段
- 关联查询
- 表结构设计及实体类
- 多对一&一对一
- 一对多
- 多对多
- 嵌套查询(多条sql)
- 多对一&一对一
- 一对多
- 多对多
- 加载策略
- 缓存
- 一级缓存
- 二级缓存
- 配置进阶
- properties
- mapper注册
- 连接池
- 注解开发
- spring
- 基础
- maven依赖
- bean创建
- 基础配置
- 测试代码
- 简单原理
- 构造方法创建对象
- 静态工厂创建对象
- 动态工厂创建对象
- 作用域
- 初始化&销毁方法
- 单例和原型作用域
- 依赖注入
- 构造方法注入
- set方法注入
- 集合&数组属性注入
- 配置文件模块化
- 注解配置
- 配置相关
- 注解释义
- 纯注解配置
- 小结
- Spring整合junit
- 依赖管理
- 使用
- Aop
- 依赖管理
- 配置相关
- aopDemo(非环绕通知)
- 名词解释
- 环绕通知
- xml混合注解Aop开发
- 纯注解Aop
- Aop事务
- 代理相关
- 动态代理观光代码
- cglib代理观光代码
- SpringMVC
- 基础
- 依赖管理
- 配置web.xml
- spring-mvc.xml
- idea tomcat配置
- Hello Controller
- Api解析
- @Controller
- @RequestMapping
- 编码问题解决
- 获取请求头信息
- 获取Cookie的值
- json相关
- 依赖管理
- 接收json请求参数
- 以json形式返回给客户端
- restful风格
- 转发
- 重定向
- 页面传值
- Request域
- Session域
- Aop异常处理
- 拦截器
- 番外篇
- Tomcat
- Servlet
- 创建
- 线程安全问题
- 生命周期相关
- Filter
- Listener
- ssm整合
- mybatis基础篇
- mybatis依赖
- mybatis实体
- Mapper接口
- mybatis配置
- 测试代码
- spring基础篇
- 依赖
- AccountService接口
- AccountServiceImpl
- 测试代码
- springmvc
- 依赖
- web.xml
- spring-mvc.xml
- AccountController
- spring整合mybatis
- 依赖
- 配置
- spring整合springmvc
- web.xml
- SpringBoot
- maven配置
- 引入SpringBoot技术
- 入口及测试控制器
- 打包插件
- 配置相关
- 配置实践
- 配置自动适配
- 配置校验
- 配置文件制定
- SpringBoot整合Junit
- 整合mybatis
- 依赖管理
- 配置相关
- @Mapper
- 整合freemarker
- 依赖管理
- 配置相关
- 测试控制器
- 目录相关
- 验证器
- maven依赖
- 验证器定义
- 控制器接收参数
- 全局异常通知
- filter跨域解决方案
- 模板相关问题
- 上传解决方案
- redis相关
- maven依赖管理
- 配置相关
- cache简单封装
- json处理
- SpringCloud
- 简介
- 版本号
- eureka
- 简介
- 组件
- eureka服务依赖
- eureka配置
- 项目启动
- 父类依赖库
- eureka_cli
- eureka客户端依赖
- 配置项
- 启动项
- eureka集群原理
- ribbon
- maven
- 配置
- 微服务实战
- 项目架构
- 基类依赖
- eureka注册中心
- 1依赖相关
- 2.配置相关
- 3.启动项
- 业务service
- supergo-manager-service
- 依赖
- 配置
- 数据源监控
- 启动项
- feign调用
- supergo-manager-feign
- 依赖
- 调用代码
- 接口层
- supergo-manager-web
- 依赖
- 配置项
- 启动项
- 通用mapper
- 逆向工程
- 数据库连接配置
- 逆向工程配置
- 操作
- base-service
- 简介
- 跨域
- 网关层
- zuul
- 依赖项
- 配置
- 启动项