微服务优缺点以及如何拆分

微服务优点

1,降低代码逻辑复杂度。

单个微服务模块相当于一个项目,开发人员只用关心这个模块的逻辑即可。

2,技术栈更加灵活

不同的微服务可以使用合适的语言架构实现,然后把服务注册到一个注册中心即可相互调用。

3,按需伸缩

当某一个模块达到瓶颈时,可针对模块多部署几个实例,从而提高整体吞吐量。

4,提高代码通用性

比如系统有订单,会员两个模块,后面有其他项目有会员功能,我们可以单独把会员模块拿过来使用。

缺点:

1,处理故障难度高

微服务架构是一个分布式系统,各模块运行在独立的进程中,出问题时可能需要逐个排查

2,部署工作量大

每个实例都需要配置部署和监控

3,分布式系统常见问题

模块之间通过rpc协议通信,提高了出错概率,分布式事务,分布式日志收集都是我们面临需要解决的问题。
微服务应该怎么拆分

1,根据业务拆分,根据业务功能对微服务进行才分,明确服务的业务场景,在设计时需要考虑业务的可划分性,不易将过于细小的业务片段独立成服务,做到每个模块高内聚低耦合。

2,功能拆分

在业务划分的基础上可以再进行配套服务的功能拆分,可以选择将某一个服务的相对独立的功能拆解出来单独成服务,在功能的拆分过程中需要考虑拆分后的服务所需的数据存储,运行环境是否能够满足。

3,数据拆分,在实际的运行过程中也需要考虑服务之间的数据交互,在进行服务拆分的时候,会出现一些公共的数据存在多个服务之间,这个时候可能需要按照一定的原则对数据进行拆分,一般来说数据拆分将划分为单一负责一部分数据的服务,避免多服务之间进行数据交互。

4,接口拆分

在微服务架构中服务之间通过暴露接口来实现交互,在服务划分的过程中我们还需要考虑服务间的接口拆分,拆分出来的每个服务都应该对暴露一部分接口以供其他服务调用。

接口拆分主要是根据服务的功能和使用场景进行合理的接口设计。

5,微服务的拆分粒度,2-3个人维护一个微服务。

6,一个微服务对一个数据库

相关推荐
暗黑小白1 分钟前
第六篇:本地模型选型 —— 4 个模型 × 2 种设备 × 2 项任务的全量对比
架构·ai agent
syc78901235 分钟前
同架构编码工具实测 口述开发场景体验对比
人工智能·架构
暗黑小白6 分钟前
第五篇:Reranker 与 BM25 —— 在精排提升与降级可靠性之间划一条线
架构·ai agent
一切皆是因缘际会8 分钟前
隐层表征解构:LLM感知式幻觉稀疏成因
算法·数学建模·ai·架构
暗黑小白9 分钟前
第十篇:纠纷协调与可观测性 —— 多Agent协作的全链路追踪
架构·ai agent
java_cj12 分钟前
从kubectl源码学Cobra:打造专业级Go命令行工具的完整实践
运维·开发语言·后端·云原生·golang·kubernetes·k8s
暗黑小白25 分钟前
第三篇:RAG 的三个盲区 —— 混合检索 + 图增强的渐进式进化
架构·ai agent
沪漂阿龙30 分钟前
Vector Store:FAISS、Chroma、Milvus、Qdrant、ES 怎么选?
人工智能·elasticsearch·架构·milvus·faiss
Y学院35 分钟前
Java 智能体开发实战:从核心架构到生产级落地,告别AI调用积木式编程
java·人工智能·架构
暗黑小白40 分钟前
第八篇:人在回路与内容安全 —— 当 AI 说“让我请示一下“
python·安全·架构·ai agent