目录

  • 软件架构
  • 单体架构
  • 分布式应用
  • 微服务架构
  • Serverless架构
  • 总结
  • Reference

软件架构

软件架构就是软件的基本结构,合适的架构是软件成功的最重要因素之一。这里列举了目前流行的4种软件架构。

单体架构

典型的三级架构:前端(web/手机端)+ 中间业务逻辑层 + 数据库。

这是典型的Java Spring MVC 或者Python Django框架的应用。

单体架构应用容易部署测试,但是随着需求不断增加,会变得十分臃肿,可维护性、灵活性会逐渐降低。
复杂性高:一个百万行级别的单体应用,整个项目包含的模块非常多,模块之间的边界、依赖关系容易模糊。可能添加一个简单功能都会带来隐藏的BUG
技术债务:随着时间推移、需求变更和人员更迭,会逐渐形成技术债务,已经使用的系统设计或代码难以被修改,因为应用程序种的其他模块可能会以意料之外的方式使用它
部署频率低:每次功能的变更或者缺陷的修复都会导致重新部署整个应用。全量部署的方式耗时长、影响范围大、风险高,这使得单体应用项目上线部署的频率较低。部署频率低又会导致两次发布之间会有大量的功能变更和缺陷修复,出错率比较高
可靠性差:某个应用BUG,如死循环、内存泄露,可能会导致整个应用崩溃
扩展能力受限:单体应用只能作为一个整体进行扩展,无法根据业务模块的需要进行伸缩。应用中有的模块是计算密集型,需要强劲的CPU;有的模块是IO密集型,需要更多的IO资源以及内存。这些模块部署在一起的话,不得不在硬件上做出妥协
阻碍技术创新:单体应用往往使用统一的技术平台和方案,使用相同的开发语言和框架,想要引入新框架或技术平台较难

分布式应用

中级架构,具有中间层分布式 + 数据库分布式,是单体架构的并发扩展,将一个大的系统划分为多个业务模块,然后分别部署在不同的服务器上,各个业务模块之间通过接口进行数据交互。数据库也采用分布式数据库,通过Nginx代理应用,将用户请求均衡地负载到不同地服务器上。

这种架构提供了负载均衡的能力,大大提高了系统的负载能力,解决了网站高并发的需求,另外还有以下特点:
解耦:模块炒粉,使用接口通信,降低了模块之间的耦合度
责任清晰:拆解为若干个子项目,不同的团队负责不同的子项目
扩展方便:增加功能时只需要增加一个子项目,调用其他系统的接口就可以
部署方便:分布式部署
提高代码复用性:比如service层,如果不采用分布式服务方式架构,就会在pc、android、ios每个端都要写一个service层逻辑,开发量大,难以维护一起升级,此时可以用分布式rest服务方式,共用一个service层
缺点就是系统之间的交互要使用远程通信,接口发开增大工作量,但是利大于弊端

微服务架构

微服务架构主要是中间层分解,将系统拆分成很多小应用(微服务),微服务可以部署在不同的服务器上,也可以部署在相同的服务器的不同容器上。但应用的故障不会影响到其他应用,单应用的负载也不会影响到其他应用,代表框架Spring cloudDubbo
微服务有以下特点:

易于开发和维护:一个微服务只会关注一个特定的业务功能,所以业务清晰、代码量较少。开发和维护单个微服务比较简单。
单个微服务启动较快:单个微服务代码量少,所以启动快
局部修改容易部署:单体应用只要有修改就得重新部署整个应用,而某个微服务修改只需要重新部署整个服务即可
技术栈不受限制
使用微服务也是有代价的:
运维要求高:更多的服务意味着更多的运维投入,微服务中需要保证几十个几百个服务的正常运行和协作
分布式固有的复杂性:微服务构建的仍然是分布式系统,系统容错、网络延迟、分布式事务也比较头疼
接口调整成本高:微服务之间通过接口进行通信,如果修改某一个微服务的API,那么所有使用该接口的微服务都需要进行调整
重复劳动:很多服务可能都会使用到相同的功能,但是这个功能并没有达到分解为一个微服务的程度,所以各个服务都会开发这个功能,从而导致代码重复。尽管可以使用共享库,但是共享库在多语言环境下不一定能用

Serverless架构

Serverless架构能够让开发者在构建应用的过程中无需关注计算资源的获取和运维,由平台来按需分配计算资源并保证应用执行的SLA(服务等级协议),按照调用次数进行计费,有效的节省应用成本。这有点像PaaS(平台便是服务)用户不需要关心基础设施,只需要关心业务,全自动云上资源创建和分配。

这种架构的优点如下:
低运营成本:在业务突发性极高的场景下,系统为了应对业务高峰,必须构建出能够应对峰值需求的系统,这种系统大部分时间是空闲的,这就导致了严重的资源浪费和成本上升。在微服务架构中,服务需要一直运行,在高负载情况下的每个服务都不止一个实例,这样才能完成高可用性。Serverless架构下,服务将根据用户的调用次数进行付费,如果没有东西运行,就不必付费。同时用户可以通过共享网络、硬盘、CPU等计算资源,在业务高峰通过弹性扩容方式有效应对业务峰值,在业务波谷期间将资源分享给其他用户,节约成本
简化设备运维原有的IT体系中,开发团队需要维护程序,也需要维护硬件基础设施。在此架构中,开发人员面对的是第三方的API和URL,底层硬件对于开发人员透明化。
提高可维护性:应用程序将调用多种第三方功能服务,组成最终的应用逻辑。目前的登录鉴权服务、云数据库服务等第三方服务在安全性、可用性、性能上都进行了大量优化,开发团队直接集成第三方服务,能够有效的降低开发成本

总结

目前微服务架构在四种架构中处于主流地位,很多应用第一、第二种架构的企业也开始慢慢转向微服务架构。第四种则是未来发展趋势

Reference

单体→分布式→微服务,这些年的软件架构是怎么发育的?

单体、分布式、微服务、Serverless软件架构一览相关推荐

  1. 软件架构从单体到微服务的演化

    软件架构从单体到微服务的演化 什么是软件架构 软件架构的演化 单体架构 分层架构 面向服务架构 微服务架构风格 什么是微服务架构 微服务架构的特点 微服务架构的核心模式 微服务架构的实现 总结 什么是 ...

  2. 单体 soa 微服务 区别_每日一读-从单体到微服务,这些年架构的演变

    写在前面的话 Stay Hungry Stay Foolish!!! 每天进步一点点!!! <每日一读>是博主每日学习的一篇文章所记录的笔记,大多数是提取文章中关键内容而成:文章类型不限, ...

  3. 2022面试200题目和答案分布式+微服务+MYSQL+Redis+JVM+Spring

    200题目和答案分布式+微服务+MYSQL+Redis+JVM+Spring等等 带图MD在资源https://download.csdn.net/download/m0_47987937/86509 ...

  4. spring cloud java b2b2c o2o分布式 微服务电子商务平台

    大型企业分布式互联网电子商务平台,推出PC+微信+APP+云服务的云商平台系统,其中包括B2B.B2C.C2C.O2O.新零售.直播电商等子平台. 需要JAVA Spring Cloud大型企业分布式 ...

  5. 十分钟搞定JeecgBoot 单体升级微服务!

    JeecgBoot自开源来被问最多的就是微服务版本什么时间出呢??微服务是个趋势,特别随着中台概念的兴趣,每个公司对微服务的需求都很迫切.针对大家的需求,我们推出了Jeecg-Cloud版本采用的Sp ...

  6. JeecgBoot 单体升级微服务快速方案(十分钟搞定)

    JeecgBoot 单体升级微服务方案(十分钟搞定) 当前系统分为system.demo 等模块,现有需求把每个模块单独启动作为微服务应用,故而推出新版boot[20200812beta],支持快速切 ...

  7. unifig,是以基于 SpringCloud 的一个分布式 微服务 平台

    介绍: unifig,是以基于 SpringCloud 的一个分布式 微服务 平台. 具有 服务发现注册.配置中心.负载均衡.断路器.数据监控 . 当前开发完成b2c商场的主要业务,以及团购逻辑.是二 ...

  8. JeecgBoot单体升级微服务之二

    前言 这篇文章咱们继续单体升级微服务的过程 先说下网络下载慢问题 我用的是5G的网络 通过测速工具测速 下载速度可以达到6M/秒左右 但下载速度怎么还没鱼哦

  9. 【项目实战】Java从单体到微服务打造房产销售平台(一) - 整体概述

    Java从单体到微服务打造房产销售平台 可掌握技能:从0-1业务设计 + SpringCloud(微服务改造) https://coding.imooc.com/class/174.html

最新文章

  1. 智能车竞赛技术报告 | 双车接力组 - 黑龙江工程学院 - 睿龙二队
  2. 名校华人教授专门设局诈骗中国留学生,4年吸金超百万美元,连亲戚也没放过...
  3. 聚类之isodata算法
  4. 神器面世:让你快速在 iOS 设备上安装 Windows、Linux 等操作系统!
  5. Asp.Net MVC 教程
  6. Maven技巧和窍门:高级Reactor选项
  7. 大工17春计算机文化基础在线测试3,大工17春《计算机文化基础》在线测试3满分答案...
  8. Java 高级知识系列篇
  9. C++基于MFC编程——课程管理系统
  10. 单片机PWM舵机控制原理
  11. 适合新手的python练习(9)
  12. 安装Linux操作系统Ubuntu 22.04 LTS并配置拨号连接
  13. 【学员问答】中国人民大学与加拿大女王大学中外合作办学金融硕士项目
  14. python判断三位数水仙花数_Python如何判断一个数字是否为水仙花数
  15. 网上卖生鲜产品怎么做引流?生鲜电商的引流方法有哪些?特点是什么?
  16. MOSES的高级特征和功能
  17. SSD固态硬盘特性术语bit位设置
  18. 信贷决策问题 —— 基于国赛-19C的数据挖掘练习
  19. 笔记本打开腾讯会议显示未检测到可用摄像头,但是系统自带相机可以使用
  20. iPhone设备链接Fiddler代理的设置

热门文章

  1. 【APICloud系列|18】上架Android应用到腾讯应用包、百度手机助手、华为应用市场、小米应用商店、阿里应用分发平台需要准备哪些材料?
  2. matlab pca可视化,利用Matlab实现PCA demo展示
  3. linux 查看libusb版本,linux / libusb获取usb设备路径
  4. inheritPrototypal.js
  5. Best Time to Buy and Sell Stock with Cooldown
  6. 在物欲横流,心浮气躁的今天,毕业生靠什么来维持自己的梦想?
  7. 在Android项目中使用AspectJ
  8. Android,监控ContentProvider的数据改变
  9. 求根号m(巴比伦算法)
  10. 基于Bresenham和DDA算法画线段