微服务拆分技巧

发布时间:2024年01月12日

一、微服务架构整体思路

图片

常见场景实施建议:

拆分方式基础设施要求服务拆分落地方式

从0开始构建业务系统

按业务拆分微服务

搭建完善基础设施,按照微服务基

础设施优先级逐步落地

一步到位

单体架构微服务化

按业务拆分微服务,

先从非核心业务开始拆分

搭建完善基础设施,按照微服务基

础设施优先级逐步落地

逐步落地

粗粒度服务微服务化

按质量拆分微服务

重用已有基础设施

逐步落地

局部系统优化

按质量拆分微服务

重用已有基础设施

逐步落地

二、如何按业务拆分微服务

实际项目中的业务边界划分(1/2)

图片

实际项目中的业务边界划分(2/2)

做法风险技巧

业务专家

以业务专家意见为准

业务专家太水

从行业挖人才

粗分 + 演进

先按照某个维度粗粒度划分,后面

随着业务发展而演进,划分为细粒

度边界

太粗导致频繁演进

微服务数量 = 服务端开发人数 /3

参考业界实现

直接参考业界类似业务的划分方式

照搬导致水土不服

微服务数量 = 服务端开发人数 /3

实际项目中的服务拆分

图片

服务拆分技巧

图片

三个火枪手案例(微服务数量 = 服务端开发人数 /3)

图片

一对一服务映射

图片

多对一服务映射

图片

一对多服务拆分技巧 - 业务流程拆分

图片

?

三、如何按质量属性拆分微服务

按性能拆分

方法:根据运维系统统计请求量排名前3的业务,将流量最大的业务以及强关联的业务拆分出来。

目的:降低业务互相影响程度,拆分后优化流量大的业务,提升性能降低成本。

按业务重要程度拆分

方法:将重要程度高的业务拆分出来,注意重要程度高不一定是流量大的。

目的:降低业务互相影响程度,拆分后提升重要程度高的业务的可用性。

案例:儿童电话手表的电话功能。平时的电话都是不怎么用的,但是只要打电话都是非常紧急的事情,都是家长在找孩子,所以虽然使用频率不高,但是只要一使用都很紧急。

按可用性拆分

方法:将经常出问题的业务拆分出来。

目的:降低业务互相影响程度,拆分后有针对性的提升问题多的业务。

按稳定性拆分

方法:将稳定的业务拆分出来。

目的:降低业务互相影响程度,拆分后有利于不断变化的业务快速迭代。

思维导图

图片

?四、粉丝福利

最近很多同学问我有没有java学习资料,我根据我从小白到架构师多年的学习经验整理出来了一份50W字面试解析文档、简历模板、学习路线图、java必看学习书籍 、 需要的小伙伴 可以关注我
公众号:“ 灰灰聊架构 ”, 回复暗号:“ 321 ”即可获取

文章来源:https://blog.csdn.net/sinat_53467514/article/details/135557114
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。