微服务基础设施怎么建设,如何选择微服务框架

微服务基础设施架构全貌

微服务 vs SOA

微服务基础设施优先级

微服务框架核心

模式1-嵌入式SDK式

【优点】

  1. 架构简单,天然支持高性能、高可用;

  2. 维护简单,无需维护独立的 Proxy 节点。

【缺点】

  1. 应用侵入,需要集成 SDK,并联动升级;

  2. 多语言重复开发 SDK

模式2-反向代理式

【优点】

  1. 应用无侵入;

  2. 天然支持多语言。

【缺点】

  1. Service Proxy 需要通过集群来做高性能、高可用;

  2. 维护复杂,需要维护 Service Proxy 集群。

模式3 - 网络代理式(Service Mesh)

【优点】

  1. 应用无侵入;

  2. 天然支持多语言;

  3. 天然支持架构高性能、高可用。

【缺点】

  1. 维护复杂,需要维护每台服务器上的 Service Proxy;

  2. 单台服务器的 Service Proxy 是单点;

  3. 全链路请求性能会下降。

微服务框架模式对比

|------|---------------|-------------------|-------------------------|
| | 嵌入SDK | 反向代理 | 网络代理 |
| 多语言 | 每个语言都需要开发SDK | 天然支持多语言 | 天然支持多语言 |
| 应用侵入 | 需要集成SDK | 无 | 无 |
| 可维护性 | 无需额外维护工作 | 维护Proxy服务器集群 | 维护每台机器上的Proxy节点,数量非常多。 |
| 高性能 | 天然支持 | 需要通过Proxy集群来实现 | 整体架构是高性能的,但全链路请求性能会下降 |
| 高可用 | 天然支持 | 需要通过Proxy集群来实现 | 整体架构高可用,单台服务器上的proxy是单点 |
| 适应场景 | 团队技术栈统一为单个单语言 | 团队技术栈多语言,服务集群规模不大 | 团队技术栈多语言,服务集群规模超级大 |

常见的微服务框架

嵌入式 SDK 样例 - Dubbo

Apache Dubbo 是一款高性能、轻量级的开源 Java 服务框架,提供了六大核心能力:

  1. 面向接口代理的高性能 RPC 调用;

  2. 智能容错和负载均衡;

  3. 服务自动注册和发现;

  4. 高度可扩展能力;

  5. 运行期流量调度;

  6. 可视化的服务治理与运维。

嵌入式 SDK 样例 - Spring Cloud

反向代理式案例 - APISIX

Service Mesh 案例 - Istio

如何选择开源微服务框架

相关推荐
步步为营DotNet1 小时前
深度解析CancellationToken:.NET中的优雅取消机制
java·前端·.net
码云数智-园园1 小时前
“架构之争,生态之合”:.NET 生态系统对 LoongArch 与 RISC-V 的支持深度解析
架构·.net·risc-v
JH30739 小时前
SpringBoot 优雅处理金额格式化:拦截器+自定义注解方案
java·spring boot·spring
Coder_Boy_10 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
啊森要自信10 小时前
CANN ops-cv:面向计算机视觉的 AI 硬件端高效算子库核心架构与开发逻辑
人工智能·计算机视觉·架构·cann
invicinble11 小时前
对tomcat的提供的功能与底层拓扑结构与实现机制的理解
java·tomcat
较真的菜鸟11 小时前
使用ASM和agent监控属性变化
java
黎雁·泠崖11 小时前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
2的n次方_11 小时前
CANN ascend-transformer-boost 架构解析:融合注意力算子管线、长序列分块策略与图引擎协同机制
深度学习·架构·transformer
qq_124987075312 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计