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

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

按业务组织团队

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

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

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

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

服务拆分

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

哪些服务要拆分

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

服务怎么拆分

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一、物联网的概览1.1物联网的起源1.2物联网的概念1.3物联网的应用1.4物联网技术要素1.5物联网与云计算的关系1.6物联网与大数据的关系二、软件架构演进史2.1单体架构2.2分布式应用2.3微服务架构2.4Serverless架构三、物联网云平台开发环境搭建3.1开发需要的软件与技术环境概览3.2Java环境-JDK安装3.3数据库-MySQL安装3.4高速缓存技术-redis安装3.5时序数据库-influxdb安装3.6IDE开发工具-idea 安装3.7原型图设计工具-axure安装3.8前端开发工具-vscode安装3.9容器部署-docker安装3.10消息队列-kafka安装3.11mqtt broker安装四、可视管理工具的安装4.1navicat安装与使用4.2redis 可视工具安装与使用4.3mqtt可视工具安装与使用4.4kafka可视工具安装与使用4.5代码管理工具安装git与使用五、后台开发基础知识介绍5.1数据库使用5.2Redis连接5.3Mqtt接入5.4Influxdb接入5.5Kafka接入5.6负载均衡nginx搭建5.7租户概念5.8Iass,pass,sass之间的联系六、微服务架构介绍6.1微服务核心组件介绍6.2微服务网关gateway6.3注册中心6.4配置中心6.5负载均衡6.6服务调用6.7熔断机制七、物联网平台需求分析7.1物联网云平台的背景7.2物联网云平台脑图设计7.3物联网云平台需求分析7.4物联网云平台开发计划设计八、物联网平台架构设计8.1平台服务拆分8.2物联网平台架构图设计8.3平台技术栈的选择8.4设备认证的设计8.5服务网关的设计8.6后台服务的设计 九、物联网云平台原型设计9.1登录注册页面设计9.2首页设计9.3产品页面设计9.4设备页面设计9.5数据中心页面设计十、数据库设计10.1关系数据库表设计10.1.1用户表10.1.2角色表10.1.3权限表10.1.4用户角色表10.1.5角色权限表10.1.6产品表10.1.7设备表10.1.8操作记录表10.2时序数据库表设计十一、物联网云平台接口文档设计11.1物联网云平台通信方式介绍11.2HTTP接口设计11.2.1.登录接口设计11.2.2注册接口设计11.2.3产品列表设计11.2.4产品添加设计11.2.5产品编辑接口11.2.6产品删除设计11.2.7添加设备接口11.2.8编辑设备接口11.2.9删除设备接口11.2.10添加租户接口11.2.11删除租户接口11.2.12编辑租户接口11.3mqtt主题十二、物联网云平台后台代码开发12.1.认证服务代码开发12.2产品管理代码开发12.3设备管理代码开发12.4数据分析代码开发12.5首页代码开发十三、物联网平台接口测试13.1什么是接口13.2接口测试流程13.3常见后台测试用例13.4使用postman测试接口 十四、物联网云平台前端设计14.1物联网云平台前端技术栈14.2vue环境搭建14.3element基础组件学习14.4vue admin element框架13.5vue与后台接口对接与联调 十五、物联网设备客户端开发15.1flutter介绍15.2flutter环境搭建15.3利用flutter编写第一个Android程序15.4flutter写一个程序接入物联网云平台  十六、部署与实施16.1使用idea发布docker环境16.2微服务程序部署方式介绍16.2.1使用jar包部署微服务程序16.2.2docker 部署微服务程序16.3dockerfile编写16.5负载均衡Nginx搭建与配置微服务程序 十七、物联网实例-设计一款远程电子锁17.1材料准备17.2技术原理17.3产品测试
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值