当前位置: 首页 > news >正文

【Java高阶面经】1.微服务架构核心:服务注册与发现之AP vs CP选型全攻略

在这里插入图片描述

一、CAP理论在服务注册与发现中的落地实践

1.1 CAP三要素的技术权衡

要素AP模型实现CP模型实现
一致性最终一致性(Eureka通过异步复制实现)强一致性(ZooKeeper通过ZAB协议保证)
可用性服务节点可独立响应(支持分区存活)分区期间无法保证写操作(需多数节点可用)
分区容错性必须支持(分布式系统基本要求)必须支持(通过复制协议实现)

典型场景对比

  • 电商秒杀(AP):允许部分用户看到旧服务列表,但保证页面可访问。
  • 银行转账(CP):必须等待服务状态全局一致,避免资金不一致风险。

二、AP模型深度解析:高可用优先的设计哲学

2.1 核心场景与技术实现

2.1.1 适用场景特征
  • 动态伸缩性要求高
    容器化环境中服务实例每分钟上下线超100次(如Kubernetes集群),AP模型的无主节点架构(如Eureka集群)可避免主节点成为瓶颈。
  • 读多写少操作
    服务发现请求中查询占比>90%,写入(注册/注销)频率低,允许缓存数据短暂不一致。
2.1.2 关键技术方案

Eureka架构解析
在这里插入图片描述

  • 心跳机制:服务实例每30秒发送心跳,超时90秒标记为失效。
  • 缓存策略:客户端缓存服务列表,默认30秒更新一次,注册中心宕机时仍可调用。
  • 自我保护模式:当心跳失败比例>85%,停止剔除服务实例,避免网络分区误判。

Consul AP模式配置

# consul配置文件
datacenter = "dc1"
server = true
bootstrap_expect = 3
# 开启AP模式(牺牲强一致性换取可用性)
disable_leader = true
disable_gossip = true

三、CP模型深度解析:强一致性优先的设计哲学

3.1 核心场景与技术实现

3.1.1 适用场景特征
  • 分布式协调需求
    如Kubernetes的节点注册(需保证Pod列表实时一致)、分布式锁(如Redlock)。
  • 配置中心场景
    服务配置变更(如限流规则)需秒级同步到所有节点,避免部分节点使用旧配置导致故障。
3.1.2 关键技术方案

ZooKeeper一致性实现

相关文章:

  • 电子电器架构 --- 汽车高性能计算
  • 关于 APK 反编译与重构工具集
  • Spring Boot-Swagger离线文档(插件方式)
  • C++(3)
  • 鸿蒙开发进阶:深入解析ArkTS语言特性与开发范式
  • 关于 Web 漏洞原理与利用:3. CSRF(跨站请求伪造)
  • Python _day31
  • 第40天-Python开发音乐播放器完整指南
  • Java 10IO流
  • [Java] idea的调试介绍
  • P2670 [NOIP 2015 普及组] 扫雷游戏
  • 软件设计师考试三大核心算法考点深度解析(红黑树 / 拓扑排序 / KMP 算法)真题考点分析——求三连
  • centos7配置静态ip 网关 DNS
  • C++中的宏
  • 解码数据语言:如何优雅的进行数仓字典建设?
  • Web开发-Python应用Flask框架Jinja模版绑定路由参数传递页面解析SSTI注入
  • 协程+Flow:现代异步编程范式,替代RxJava的完整实践指南
  • PH热榜 | 2025-05-20
  • springboot框架 集成海康ISUP-SDK 并实现 协议透传给设备下发指令!
  • 武汉科技大学人工智能与演化计算实验室许志伟课题组参加第八届智能优化与调度学术会议
  • 中英举行人工智能对话
  • 上海合作组织减贫和可持续发展论坛开幕,沈跃跃宣读习近平主席贺信
  • 学生靠老干妈下饭、职工餐肉类又多又好?纪委出手整治
  • 国家统计局:1-4月份,全国固定资产投资同比增长4.0%
  • 聘期三年已至:37岁香港青年叶家麟卸任三亚市旅游发展局局长
  • 人民日报头版:紧盯“学查改”,推动作风建设走深走实