体系化认识微服务之二:如何实施微服务架构

2024-05-30 16:32

本文主要是介绍体系化认识微服务之二:如何实施微服务架构,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

微服务作为一种架构风格,其主要特点是由很多小的服务组成,且每个服务都是可独立部署的,任何 一个服务的升级部署都不会影响其他的服务。那么在企业中如何实施 微服务这种架构呢?

按业务组织团队

康威法则:设计系统的组织,其产生的架构设计等价于族之间的沟通架构
在以往传统的软件架构中,所有的功能都是在一个单体系统中完成的,每个团队都可以在上面修改代码,开发测试部署也比较方面。但是随着业务的扩展和功能的不断迭代,单体系统越来越难以维护,故障率不断上升。

康威法则其实解决的是多团队并行开发的痛点,不同的业务有不同的团队维护,每个团队维护他们自己的服务,团队的边界会更加清晰,开发效率也会大幅提升。

按业务组织团队带来的结果是,每个需求的开发都是按产品进行交付的。也就是说需求的开发是跨团队的,这个团队会有各个职能部门的同学,比如产品经理、工程师、测试、DBA、运维等角色。

微服务产品交付流程如下:
微服务产品呢交付流程
第一阶段:产品经理会组织需求评审,明确这个产品要做什么,如果需求比较会先进行可能性评审
第二阶段:由于最终是以产品进行交付的,在实际开发中会明确一个项目负责人,他会给出这个产品的技术文档,明确每个人要做什么以及怎么做的问题
第三阶段:给出方案后,不同职能部门的人员各自进行开发
第四阶段:开发完毕后,把产品(一般会有多个项目,每个项目不同的分支)交付给测试人员进行测试
第五阶段:测试完后,把产品交付给运维进行构建部署
第六阶段:运维构建部署后,开发人员发布上线
第七阶段:线上观察反馈,验证产品质量。如果有问题,产品重新提需求,进入一个闭环

服务拆分

单体应用要改成微服务架构的首要问题是,有哪些服务或者模块是要拆分出去,并且哪些服务要归属到各个业务团队;这些众多的服务要怎么拆分。

哪些服务要拆分

所有的服务按照业务维度可以分为两种:业务相关和业务无关的服务。
业务无关的服务包括存储基础服务、公共服务。存储基础服务又可以分为数据库、缓存。公共服务分为短信服务、邮件服务、地图服务等。
业务相关的包括领域服务、存储领域服务。这里存储服务包括业务无关的服务,比如赠增删改查,又包括特定条件查询服务等和业务相关的存储服务。

服务怎么拆分

将需要拆分的服务梳理后还有一个问题要解决,这些服务怎么拆分。我们按照从底层到上层的方法拆分不同的服务,从底层到上层分别为:数据层服务、业务服务。
数据层服务是与业务无关的服务,把底层访问数据的细节以服务的方式提供出去,例如我们拆分出了经纬度服务、地图服务业务、城市服务等底层数据服务。业务服务是核心服务,把数据层服务+业务逻辑组合起来构成业务服务,业务服务把底层访问数据层的服务屏蔽起来,调用方不用关心具体细节,例如我们把订单和商家分为两个业务服务,按照业务的领域可以分为更多的业务服务。

这篇关于体系化认识微服务之二:如何实施微服务架构的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1016521

相关文章

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

springboot项目如何开启https服务

《springboot项目如何开启https服务》:本文主要介绍springboot项目如何开启https服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录springboot项目开启https服务1. 生成SSL证书密钥库使用keytool生成自签名证书将

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳

Java异常架构Exception(异常)详解

《Java异常架构Exception(异常)详解》:本文主要介绍Java异常架构Exception(异常),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. Exception 类的概述Exception的分类2. 受检异常(Checked Exception)

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

SpringCloud之LoadBalancer负载均衡服务调用过程

《SpringCloud之LoadBalancer负载均衡服务调用过程》:本文主要介绍SpringCloud之LoadBalancer负载均衡服务调用过程,具有很好的参考价值,希望对大家有所帮助,... 目录前言一、LoadBalancer是什么?二、使用步骤1、启动consul2、客户端加入依赖3、以服务

Nginx配置系统服务&设置环境变量方式

《Nginx配置系统服务&设置环境变量方式》本文介绍了如何将Nginx配置为系统服务并设置环境变量,以便更方便地对Nginx进行操作,通过配置系统服务,可以使用系统命令来启动、停止或重新加载Nginx... 目录1.Nginx操作问题2.配置系统服android务3.设置环境变量总结1.Nginx操作问题

springboot的调度服务与异步服务使用详解

《springboot的调度服务与异步服务使用详解》本文主要介绍了Java的ScheduledExecutorService接口和SpringBoot中如何使用调度线程池,包括核心参数、创建方式、自定... 目录1.调度服务1.1.JDK之ScheduledExecutorService1.2.spring

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后