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

微服务优点

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

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

2,技术栈更加灵活

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

3,按需伸缩

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

4,提高代码通用性

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

缺点:

1,处理故障难度高

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

2,部署工作量大

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

3,分布式系统常见问题

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

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

2,功能拆分

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

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

4,接口拆分

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

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

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

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

相关推荐
vortex53 分钟前
什么是Unix哲学?或者:如何像克尼汉一样思考、像里奇一样编码、像汤普森一样架构
java·架构·unix
七宝大爷11 分钟前
Transformer架构变体全景图:从BERT到GPT的演化路径
架构·bert·transformer
重生之我是Java开发战士12 分钟前
【Java SE】TCP/IP协议栈:从分层架构到核心机制
java·tcp/ip·架构
张人大 Renda Zhang13 分钟前
Maven = Java 构建世界的“事实标准”:从 pom.xml 到云原生 CI/CD
xml·java·spring boot·后端·ci/cd·云原生·maven
小毅&Nora15 分钟前
【云计算】【Kubernetes】 ② K8S的架构、应用及源码解析 - Pod 生命周期管理与 CRI 集成详解
架构·kubernetes·云计算
人工智能训练20 分钟前
跨架构突围!X86 Ubuntu Dify 无缝迁移 Arm64 openEuler Docker 实战指南
人工智能·ubuntu·docker·容器·架构·arm64·dify
初学者,亦行者21 分钟前
【探索实战】监控、安全与边缘场景的深度落地
云原生
AI云原生24 分钟前
Docker部署多个Python项目如何使用Nginx实现负载均衡的解决方案
python·nginx·docker·云原生·容器·kubernetes·负载均衡
Gavin在路上29 分钟前
架构设计之COLA架构实战
架构
拾忆,想起30 分钟前
Dubbo服务调用失败调试指南:从问题定位到快速修复
前端·微服务·架构·dubbo·safari