首页 > 其他分享 >从后微服务谈架构演进.240109

从后微服务谈架构演进.240109

时间:2025-01-06 09:48:57浏览次数:7  
标签:后微 时代 服务 演进 从后 单体 架构 调用 240109

2022 年,关于微服务发生了几件有趣的事情。

其一,正式掌管 Twitter 不久的 Elon Musk 对 Twitter 的开发团队 “批判” 了一番。他表示自己为 Twitter 在许多国家的极慢运行速度感到抱歉。之所以如此慢是因为 App 需要执行 1000 多个 “糟糕” 的批处理 RPC,而这只是为了渲染主页的时间线。Musk 表示 “今天的部分工作将是关闭臃肿的"微服务" 。实际上,只有不到 20% 的微服务是 Twitter 需要的。”

其二,GitHub 前 CTO Jason Warner 在社交媒体上表示:“我确信过去十年中,最大的架构错误之一就是全面使用微服务。” “任何构建过大型分布式系统的人都知道他们并不真的那样工作,但还必须适应它。”

那么,微服务架构是否是一个错误,或者微服务是否已经过时了呢?

Martin Fowler发现所有成功的微服务都遵循了通用的模式:
1、几乎所有成功的微服务故事,都是从一个变得太大而被分解的单体开始的。
2、几乎所有我听说过的从头开始构建为微服务系统的系统都以严重的麻烦告终。
这种模式导致Martin Fowler的许多同事认为:“你不应该用微服务开始一个新的项目,即使你确信你的应用程序将足够大,值得这么做...”

演进中的架构

①原始分布式时代
为了突破硬件算力的限制,寻找使用多台计算机共同协作来支撑同一套软件系统运行的可行方案,此时是对分布式架构最原始的探索。

②单体系统时代
单体架构(Monolithic):“单体”只是表明系统中主要的过程调用都是进程内调用,不会发生进程间通信,仅此而已。

③SOA时代
SOA 架构(Service-Oriented Architecture):面向服务的架构是一次具体地、系统性地成功解决分布式服务主要问题的架构模式。

④微服务时代
微服务架构(Microservices):微服务是一种通过多个小型服务组合来构建单个应用的架构风格,这些服务围绕业务能力而非特定的技术标准来构建。各个服务可以采用不同的编程语言,不同的数据存储技术,运行在不同的进程之中。服务采取轻量级的通信机制和自动化的部署机制实现通信与运维。

⑤后微服务时代
后微服务时代(Cloud Native):从软件层面独力应对微服务架构问题,发展到软、硬一体,合力应对架构问题的时代,此即为“后微服务时代”。

⑥无服务架构
无服务架构(Serverless):如果说微服务架构是分布式系统这条路的极致,那无服务架构,也许就是“不分布式”的云端系统这条路的起点。

绝对意义上的无限性能必然是不存在的,但在云计算落地已有十年时间的今日,相对意义的无限性能已经成为了现实。

总结:

  • 原始分布式时代:出现调用远程方法的想法,并且开始实施寻找解决的方式。
  • 单体系统时代:整个服务一致运行在单体服务器中,没有调用远程服务的特点,缺点就是对于大型项目难扩展。
  • SOA时代:明确了采用 SOAP 作为远程调用的协议,依靠 SOAP 协议族来进行实现远程调用。
  • 微服务时代:拆分为多个服务,并且有一系列远程调用方法的解决技术方案。
  • 后微服务时代:借助容器来对服务进行发布、部署、监控等一系列自动化操作。

标签:后微,时代,服务,演进,从后,单体,架构,调用,240109
From: https://www.cnblogs.com/amadeuslee/p/18654504

相关文章

  • 企业数字化转型,数据治理是关键.240109
    企业数字化转型是大势所趋,通过数据治理、数据平台建设、数据分析与建模,把数据变成服务,使数据能在企业内顺畅流动起来,为企业带来巨大的价值。数据是企业数字化转型的重要基础。数据能创造价值,但数据创造价值的功能并不能由数据自身来直接实现,数据要素也不能直接参与价值分配,而是要......
  • 数据治理-数据资产管理.240109
    在组织中,并非所有的数据都构成数据资产,数据资产是能够为组织产生价值的数据,数据资产的形成需要对数据进行主动管理并形成有效控制。数据资产管理是规划、控制和提供数据及信息资产的一组业务职能,包括开发、执行、监控和共享数据资产(元数据、指标、维度、数据服务接口、标签、文件......
  • Gitlab误删用户导致项目丢失莫慌.240109
    Gitlab让小朋友不小心把离职员工的账号给删了,可是离职员工有好几个项目都是他是owner,造成Gitlab上项目全部丢失。遇到这种情况,莫慌。一般,本地都有完整的Git备份,离职员工走了,肯定他的主管有整套代码。解决方式很简单,跟着我来,就不会错。但是建议,创建项目,owner最好是管理员创建,......
  • Navicat连接Oracle数据库报错:oracle library is not loaded解决方法.240109
    连接Oracle时提示“oraclelibraryisnotloaded”。去Oracle官网下载OracleInstantClientDownloads。https://www.oracle.com/database/technologies/instant-client/downloads.html修改OCIlibrary下载好的文件包解压到D盘,记住路径。打开NavicatPremium程序,打开“......
  • Winserver主副域控切换的方法.240109
    ​查看当前的dcnetdomquerydc步骤登录主域控(PDC),例如主域控的主机名为dc01.yourdomaincontroller.com(FQDN格式)打开CMD命令行终端,输入netdomqueryfsmo查看当前谁是PDC,输入ntdsutil回车再输入roles回车,再输入connections回车,再输入connecttoserverdc02.yourdo......
  • Esxi缩小硬盘大小的办法.240109
    1.​进虚拟机,把要缩减硬盘的那个系统,磁盘管理,收缩卷收缩了。然后关机。本例:调整800G到350G。2.Esxi打开ssh,进去。cd/vmfs/volumes/<datastorename>/<VMfolder_name>datastorename,完全靠猜,ls-lrt看下大小,捡大点的cd进去看看是哪个。本例:/vmfs/volumes/643e1d69-1d07799......
  • Gitlab的备份与恢复,异机转移.240109
    ​注意:异机转移的时候,gitlab的版本必须一致。一、备份GitLab数据停止GitLab服务gitlab-ctlstopunicorngitlab-ctlstopsidekiq创建GitLab备份mkdirgitlabBackgitlab-rakegitlab:backup:createBACKUP=gitlabBak230815cd/var/opt/gitlab/backups/mvgitlabBak......
  • LruCache在美团DSP系统中的应用演进15
     背景DSP系统是互联网广告需求方平台,用于承接媒体流量,投放广告。业务特点是并发度高,平均响应低(百毫秒)。为了能够有效提高DSP系统的性能,美团平台引入了一种带有清退机制的缓存结构LruCache(LeastRecentlyUsedCache),在目前的DSP系统中,使用LruCache+键值存储数据库的机制......
  • LruCache在美团DSP系统中的应用演进13
     背景DSP系统是互联网广告需求方平台,用于承接媒体流量,投放广告。业务特点是并发度高,平均响应低(百毫秒)。为了能够有效提高DSP系统的性能,美团平台引入了一种带有清退机制的缓存结构LruCache(LeastRecentlyUsedCache),在目前的DSP系统中,使用LruCache+键值存储数据库的机制......
  • LruCache在美团DSP系统中的应用演进11
     背景DSP系统是互联网广告需求方平台,用于承接媒体流量,投放广告。业务特点是并发度高,平均响应低(百毫秒)。为了能够有效提高DSP系统的性能,美团平台引入了一种带有清退机制的缓存结构LruCache(LeastRecentlyUsedCache),在目前的DSP系统中,使用LruCache+键值存储数据库的机制......