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

2024-05-30 16:32

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

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

按业务组织团队

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

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

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

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

服务拆分

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

哪些服务要拆分

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

服务怎么拆分

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

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



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

相关文章

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

mybatis的整体架构

mybatis的整体架构分为三层: 1.基础支持层 该层包括:数据源模块、事务管理模块、缓存模块、Binding模块、反射模块、类型转换模块、日志模块、资源加载模块、解析器模块 2.核心处理层 该层包括:配置解析、参数映射、SQL解析、SQL执行、结果集映射、插件 3.接口层 该层包括:SqlSession 基础支持层 该层保护mybatis的基础模块,它们为核心处理层提供了良好的支撑。

百度/小米/滴滴/京东,中台架构比较

小米中台建设实践 01 小米的三大中台建设:业务+数据+技术 业务中台--从业务说起 在中台建设中,需要规范化的服务接口、一致整合化的数据、容器化的技术组件以及弹性的基础设施。并结合业务情况,判定是否真的需要中台。 小米参考了业界优秀的案例包括移动中台、数据中台、业务中台、技术中台等,再结合其业务发展历程及业务现状,整理了中台架构的核心方法论,一是企业如何共享服务,二是如何为业务提供便利。

每天认识几个maven依赖(ActiveMQ+activemq-jaxb+activesoap+activespace+adarwin)

八、ActiveMQ 1、是什么? ActiveMQ 是一个开源的消息中间件(Message Broker),由 Apache 软件基金会开发和维护。它实现了 Java 消息服务(Java Message Service, JMS)规范,并支持多种消息传递协议,包括 AMQP、MQTT 和 OpenWire 等。 2、有什么用? 可靠性:ActiveMQ 提供了消息持久性和事务支持,确保消

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

安全管理体系化的智慧油站开源了。

AI视频监控平台简介 AI视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。用户只需在界面上进行简单的操作,就可以实现全视频的接入及布控。摄像头管理模块用于多种终端设备、智能设备的接入及管理。平台支持包括摄像头等终端感知设备接入,为整个平台提

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。

如何编写Linux PCIe设备驱动器 之二

如何编写Linux PCIe设备驱动器 之二 功能(capability)集功能(capability)APIs通过pci_bus_read_config完成功能存取功能APIs参数pos常量值PCI功能结构 PCI功能IDMSI功能电源功率管理功能 功能(capability)集 功能(capability)APIs int pcie_capability_read_wo

系统架构设计师: 信息安全技术

简简单单 Online zuozuo: 简简单单 Online zuozuo 简简单单 Online zuozuo 简简单单 Online zuozuo 简简单单 Online zuozuo :本心、输入输出、结果 简简单单 Online zuozuo : 文章目录 系统架构设计师: 信息安全技术前言信息安全的基本要素:信息安全的范围:安全措施的目标:访问控制技术要素:访问控制包括:等保