草庐IT

聊聊微服务架构思想

·志坚行远· 2023-03-30 原文

用了好多年微服务架构了,我经常会反思,这个项目为啥用微服务?真的能帮我们解决一些痛点吗?这个项目有必要用微服务吗?这个项目体现出微服务的价值了吗?

我是从2017年开始入手微服务,距今已经五六年了。在此期间,遇到的大小项目,基本都是用微服务架构开发的,其中有数字化工厂项目、教辅系列平台、政府行政审批系列、商城门户SASS平台、大数据平台等待。在这篇文章中,我就不给大家普及微服务的概念及微服务组件框架,主要讨论微服务架构的发展和核心思想。


只要学会举一反三,懂得总结归纳,从常见事务中剥离方法论,你就会发现,其实软件架构的发展,到现在的微服务,都是有迹可循。

先聊聊历史政治的历程

个人认知,说几个关键历程

  1. 最初的人文部落管理,扁平化管理,大家都跟着部落首领干,男的打猎,女的耕织,部落首领说了算。规模不大,统治者一言堂,管得过来。
  2. 随着各部落的壮大发展,部落间混战,最终轩辕氏皇帝征服其他部落,成部落联盟首领,再到后来的夏商周三代,基本形成了分封制的管理格局。规模越来越大,管不过来了。分封而治,权利下放。
  3. 春秋战国,诸侯崛起,周王室衰落,最终秦一统天下。吸取权利下放导致尾大不掉的弊病。于是始皇帝建立郡县制的同时,统一制度,统一思想,收缴天下兵马。权利下放,各管各的,容易失控。需要将权利按职能分类,选择性下放,同时建立统一的管理制度。
    值得一提的,汉孝武黄帝,提出了天下第一阳谋的“推恩令”,彻底维护了郡县制的落实,防止了重返分封制。
  4. 随着长期发展,直到今日,形成了围绕中央政权,成立个多个司法部门,按职能管理的格局。高内聚(按职能成立各种司法部门,统一管理),低耦合(金字塔模式,建立省市县镇村多级。将部分权利逐层下放,各管一方)

简说创业者管理旅程

  1. 常规创业者,创业一开始,所有的活,从生产到销售一条龙服务,都是老板自己干,亲力亲为。
  2. 业务发展到一定规模,老板忙不过来了,请了几个员工一起干,干的好的,积累了经验,可能撇开老板自己出去创业了跟自己竞争了,管理失控,老板尴尬了。
  3. 于是,招聘了不同能力的人,划分智能部门干活,让专业的人干专业的事,离了萝卜坑还在,只要体系在,就能稳固发展,铁打的营盘流水的兵。
  4. 随着公司业务规模越来越大,光靠只能职能部门也没办法管理庞大的业务,于是成立分公司,子公司,大区部门等,建立金字塔模式,逐层下放。这时候的老板管理基本就靠制度、企业文化、战略、组织架构、机制等来管理企业了。

软件架构的发展

软件架构的发展,其实也是一样的,都有个从0到1(质变),从1到n(量变)的过程。不同时期下的管理思想在一定程度上是相似的。
(结合个人经验,以web发展发展为例说起)

  1. 微软asp框架说起,asp框架将html,js,css(前端),c#/vb(后端代码),jdbc-sql(数据库),系统配置等全部放在.asp文件中,开发一个功能,直接操作数据库,查询到数据,就遍历渲染了,很直接。开发起来真的很方便简介,但维护起来却非常困难,后期文件极其臃肿,且代码复用性极差,当遇到大的项目,需要大的开发团队,分工、管理、规划就显得极难。
  2. 后来,asp.net框架出来,做到前后端分离(文件维度)html,js,css(前端)放在.asp文件,c#(后端代码)放在.cs文件中。甚至MVC框架的出现,将软件架构进一步拆分为前端展现层-后端(业务控制层-业务处理层-数据库持久层) 4层,从上到下,底层代码的复用性得到了极大的提高,每一层可以隔离开发。(PS:当时我也转JAVA了,java跨平台太香了。asp.net有点对应java的SSH三大框架,以下以java为例接着说)。
  3. 再后来,随着angularJS、restApi的出现,前端只需要接口提供的数据就可完独立完成交互,不再依赖后端渲染,权限、配置控制等,可独立部署,掀起来前后端分离的格局(项目维度),随后angularJS2+、vue、react + spring boot的架构得到开发者青睐。这时候迎来了前后端独立的大发展阶段,前端没了后端的束缚,基于mockjs或node,迅速响应市场,快速提供可见软件,并逐步形成前端框架;后端也是从业务角度,解耦业务,拆分项目,形成一个前端,需要多个后端服务提供接口的局面,然而后端面服务拆分的越多,越难管控。
  4. 微服务框架的诞生就是为这些业务服务提供一系列工具组件去统一管理起来。

总结一下,如下图:

再回头看一下微服务架构,你会发现,核心业务被一堆抽离出来的职能管理服务团团包围。


微服务架构的核心思想

软件架构的核心思想是“高内聚、低耦合”,所以任何架构的改造和设计模式都是向这两个核心思想靠拢。

微服务最关键的是拆分微服务,按业务属性和功能属性,可以分为纵向拆分和横向拆分。其拆分的目的,主要还是为了业务解耦。业务解耦的目的:

  1. 并行开发
    大的项目,一般开发周期会比较长,如果规划的好,微服务可以并行开发,提高人效和缩短开发周期;
  2. 复用性和可移植性
    一个独立完整的功能,可以复用,降低维护成本,提高功能价值。
  3. 降低隐患范围,风险最小化
    防止了牵一发动全身,因为一个问题,导致系统全部瘫痪。系统更新,也可以无感局部更新。
  4. 有益于持续交付
    基于微服务低依赖性,更容易做单元测试和功能交付。
  5. 灵活交付
    特别是toB产品,不同的企业,可能要的功能范围不一样,他不想出那么多钱买你全套,只要部分功能,用微服务就可以很灵活搭配,打包不同范围的产品。

我做过很多大型项目,为了缩短工期,为了能并行开发,敏捷管理,持续交付可用功能,才选型微服务架构。然而,微服务不止是为了解决这些问题,微服务的诞生,更多是为了解决toC高并发,响应慢的问题,单体服务再性能方面扩展有限,且成本很大。而微服务通过集群部署,可以很灵活、很方便的进行性能扩展,同时保证了系统的稳定性。集群部署的目的:

  1. 高并发
    通过部署多节点,并发处理业务,突破业务并发瓶颈。
  2. 消灾、灭灾
    防止服务宕机,造成系统瘫痪,多节点部署,有备无患。

举个例子,统计整个学校学生的兴趣爱好。如果没有系统,只能线下统计,大家都能想到最快的方式,逐层统计,由下到上,班主任统计自己班的,统计完交给年级主任,年级主任统计完各年级的交给学段部,学段部校长统计完交给总校长统计。这样一个庞大的工作拆分成四级,由多人完成。不同的人干不同的事,同级别可并行处理,这极大地提升了干活的效率。这也是微服务分布式处理思想的体现,可以很好的纵向扩展业务,不限层级。但是,在统计过程中,逐层上报,汇总的时候,要去重分组筛选,越到后边工作量越来越大,总校长事务繁多,实践投入又很少,总的统计过程还是效率很低。怎么办,很简单,根据实际情况,给他们配备不同数量的助手,协助完成统计工作。即不同的人干同一件事,这降低了流水线上单个节点的压力,同时保证了流水线的运作,每件事,保证始终有人干就行。这是微服务的集群处理思想的体现,根据业务容量大小,可以灵活横向扩展节点,不限个数,同时保障了系统的可用性。
微服务的架构思想,其实还是源于日常生活,没那么复杂,只是有些人善于归纳,提炼方法论并应用到其他领域罢了!
毕!

有关聊聊微服务架构思想的更多相关文章

  1. Observability:从零开始创建 Java 微服务并监控它 (二) - 2

    这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/

  2. ruby - Ruby 和 Ruby on Rails 中的三层架构 - 2

    我是一名决定学习Ruby和RubyonRails的ASP.NETMVC开发人员。我已经有所了解并在RoR上创建了一个网站。在ASP.NETMVC上开发,我一直使用三层架构:数据层、业务层和UI(或表示)层。尝试在RubyonRails应用程序中使用这种方法,我发现没有关于它的信息(或者也许我只是找不到它?)。也许有人可以建议我如何在RubyonRails上创建或使用三层架构?附言我使用ruby​​1.9.3和RubyonRails3.2.3。 最佳答案 我建议在制作RoR应用程序时遵循RubyonRails(RoR)风格。Rails

  3. ruby-on-rails - 具有六边形架构和 DCI 模式的框架和数据库适配器 - 2

    我尝试用Ruby设计一个基于Web的应用程序。我开发了一个简单的核心应用程序,在没有框架和数据库的情况下在六边形架构中实现DCI范例。核心六边形中有小六边形和网络,数据库,日志等适配器。每个六边形都在没有数据库和框架的情况下自行运行。在这种方法中,我如何提供与数据库模型和实体类的关系作为独立于数据库的关系。我想在将来将框架从Rails更改为Sinatra或数据库。事实上,我如何在这个核心Hexagon中实现完全隔离的rails和mongodb的数据库适配器或框架适配器。有什么想法吗? 最佳答案 ROM呢?(Ruby对象映射器)。还有

  4. 设计一个亿级高并发系统架构 - 12306火车票核心场景DDD领域建模 - 2

    “架设一个亿级高并发系统,是多数程序员、架构师的工作目标。许多的技术从业人员甚至有时会降薪去寻找这样的机会。但并不是所有人都有机会主导,甚至参与这样一个系统。今天我们用12306火车票购票这样一个业务场景来做DDD领域建模。”开篇要实现软件设计、软件开发在一个统一的思想、统一的节奏下进行,就应该有一个轻量级的框架对开发过程与代码编写做一定的约束。虽然DDD是一个软件开发的方法,而不是具体的技术或框架,但拥有一个轻量级的框架仍然是必要的,为了开发一个支持DDD的框架,首先需要理解DDD的基本概念和核心的组件。一.什么是领域驱动设计(DDD)首先要知道DDD是一种开发理念,核心是维护一个反应领域概

  5. ruby - 写密集型特征的架构 - 2

    我在当前项目中使用由Oracle数据库和memcached支持的RubyonRails。有一个非常常用的功能,它依赖于单个数据库View作为数据源,并且该数据源内部有其他数据库View和表。这是一个虚拟数据库View,能够从一个地方访问所有内容,而不是物化数据库View。大多数情况下,如果用户正在使用他们希望更新的功能,那么让数据保持最新很重要。从这个View获取数据时,我将安全表内部连接到View(安全表不是View本身的一部分),其中包含一些我们用来在更细粒度级别上控制数据访问的字段。例如,安全表有user_id,prop_1,prop_2列,其中prop_1,prop_2是数据库

  6. 【思考】聊聊低代码的实践之路 - 2

    文章目录背景一、最初的疑惑二、简单聊聊原理三、组织内实践案例四、实践带来的反思五、最后聊几句问题背景这个概念由来已久,但是在国内兴起,是最近几年;低代码即Low-Code;指提供可视化开发环境,可以用来创建和管理软件应用;简单的说就是可以通过各种组件的拖拽,实现页面的创建,交互流程和逻辑,以及数据层面的管理,更加高效的实现需求;早先在数据公司时;见识过低代码的应用,也参与过部分研发,比如元数据平台,BI分析等;不过,当时还是以数据管理的工具来定义项目,并非是低代码;从「2020年底」开始;实际上,那个时间节点,低代码平台的应用已经形成趋势了;现在的公司,将低代码平台的使用规划到业务体系中;后来

  7. 【微服务笔记23】使用Spring Cloud微服务组件从0到1搭建一个微服务工程 - 2

    这篇文章,主要介绍如何使用SpringCloud微服务组件从0到1搭建一个微服务工程。目录一、从0到1搭建微服务工程1.1、基础环境说明(1)使用组件(2)微服务依赖1.2、搭建注册中心(1)引入依赖(2)配置文件(3)启动类1.3、搭建配置中心(1)引入依赖(2)配置文件(3)启动类1.4、搭建API网关(1)引入依赖(2)配置文件(3)启动类1.5、搭建服务提供者(1)引入依赖(2)配置文件(3)启动类1.6、搭建服务消费者(1)引入依赖(2)配置文件(3)启动类1.7、运行测试一、从0到1搭建微服务工程1.1、基础环境说明(1)使用组件这里主要是使用的SpringCloudNetflix

  8. ruby - 模块化、基于组件的 Sinatra 应用程序的架构 - 2

    我正在开发一个包含大约10个不同功能组件的Sinatra应用程序。我们希望能够将这些组件混合并匹配到应用程序的单独实例中,完全从config.yaml文件配置,如下所示:components:-route:'/chunky'component_type:FoodListercomponent_settings:food_type:baconmax_items:400-route:'places/paris'component_type:Mappercomponent_settings:latitude:48.85387273165654longitude:2.340087890625-

  9. 若依框架解读(微服务版)——2.模块间的调用逻辑(ruoyi-api模块)(OpenFeign)(@innerAuth) - 2

    模块之间的关系我们可以了解到一共有这么多服务,我们先启动这三个服务其中rouyi–api模块是远程调用也就是提取出来的openfeign的接口ruoyi–commom是通用工具模块其他几个都是独立的服务ruoyi-api模块api模块当中有几个提取出来的OpenFeign的接口分别为文件,日志,用户服务我们以RemoteUserService接口为例子:其中contextId="remoteUserService"为bean的名称,value=ServiceNameConstants.SYSTEM_SERVICE为接口的描述,fallbackFactory=RemoteUserFallback

  10. 【哈士奇赠书活动 - 20期】-〖从程序员到架构师〗 - 2

    文章目录⭐️赠书活动-《从程序员到架构师》⭐️编辑推荐⭐️作者简介⭐️赠书活动→获奖名单⭐️赠书活动-《从程序员到架构师》内容简介:《从程序员到架构师:大数据量、缓存、高并发、微服务、多团队协同等核心场景实战》分为数据持久化层场景实战、缓存层场景实战、基于常见组件的微服务场景实战、微服务进阶场景实战和开发运维场景实战5个部分。基于对十余个架构搭建与改造项目的经验总结,介绍了大数据量、缓存、高并发、微服务、多团队协同等核心场景下的架构设计常见问题及其通用技术方案,包含冷热分离、查询分离、分表分库、秒杀架构、注册发现、熔断、限流、微服务等具体需求下的技术选型、技术原理、技术应用、技术要点等内容,将

随机推荐