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

目录

  • 软件架构
  • 单体架构
  • 分布式应用
  • 微服务架构
  • 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

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/376862.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MyBatis3 association error - The content of element type resultMap must match (constructor?,id*,r...

MyBatis3 association error - The content of element type "resultMap" must match "(constructor?,id*,result*,association*,collection*,discriminator?)" 1.后台错误信息-问题现象: ERROR [geby:Context initialization failed] 2013-0…

Midjourney V6刷屏,但它最可怕的地方居然不是那些神图?

Midjourney在沉寂九个月后推出了Midjourney V6,这个文生图产品体现出的更细腻的细节处理,更强大的语言理解能力和更加“不像AI”的图片效果在过去几天引发一片惊呼。 作为一个闭源的模型产品,Midjourney的魔法配方并不为人所知,但…

HTTP 错误500.19 -Internal Server Error

HTTP 错误500.19 -Internal Server Error 原文:HTTP 错误500.19 -Internal Server Error HTTP 错误500.19 -Internal Server Error 错误代码 0x80070021 asp.net 2009-11-05 16:54:33 阅读484 评论1 字号:大中小 错误摘要 HTTP 错误500.19 -Internal Server Error …

连续内存分区式内存管理

目录前言分区式内存管理动态分区内存管理总结本笔记参考黄工的https://mp.weixin.qq.com/s/k0W_LqI1zBAYC1GU1U2HQA 前言 内存管理模块主要负责内存的初始化、分配以及释放。 从分配内存是否连续可以分为两大类: 1、连续内存管理 为进程分配的内存空间是连续的&a…

用DEVC++作图

小海豚学NOIP,老师说要用DEV C。 小海豚喜欢画图,记得以前用C#编些程序给她看。可前一阵打开看,我的免费Visual Studio过期了。可恶的Microsoft ,不想用盗版难道就要每个月就下载一次? 于是就用DEV C的Windows调用吧。…

Python服务器开发三:Socket

Python服务器开发三:Socket socket是操作系统中I/O的延续,它可以使进程和机器之间的通信成为可能。socket可以看成一个标准的文件描述符。不同的是文件需要用open()函数打开,而socket用socket() 函数建立.recv()、send()函数和read()、write(…

Syntax error: Bad for loop variable解决办法

在Ubuntu下写的shell文件t.sh执行时出现错误: 1 t.sh: 6: Syntax error: Bad for loop variable 从ubuntu 6.10开始,ubuntu就将之前默认的bash shell更换成了dash shell,其表现为/bin/sh链接倒了/bin/dash,而不是传统的/bin/bash&…

Linux命令常见

摘自: 常考的 21 条 Linux 命令 目录)cd,切换路径ls,查看文件与目录的命令cp,用于复制文件mv,用于移动文件、目录cat,查看文件内容find,文件搜索文件权限命令, 设置权限,-取消权限文本处理命令打包和压缩文件命令进程相…

记一次调试

这是我最近几个月来遇到的最棘手的一个问题:* 昨天花了4个小时找出第一层次的原因这个纠结啊,本来和老婆说好准时下班回家吃饭的,结果被这个问题拖了老久。这是一个gradle的plugin,用来resolve公司内部的dependency的,…

OSGi.NET 学习笔记 [模块化和插件化][小结]

【目录】-【模块化和插件化】-【小结】 现在我们来对OSGi.NET的“模块化和插件化”做一个小结,再次把官方的说明拿出来  1) 物理隔离:基于UIOSP开发的模块是一个物理隔离的可单独部署的模块,每一个模块拥有独立的文件夹、类型空…

miniob :相关环境配置

How to build 参考视频:https://www.bilibili.com/video/BV1gv411A7oA?spm_id_from333.999.0.0将代码下载并且安装编译。 git clone失败的话参考:https://blog.csdn.net/sxg0205/article/details/81412921 install cmakebuild libevent git submodul…

Fedora 20 配置

前几天装了fedora 20, 断断续续的进行了以下配置: 1. 安装oracle java及jdk版本切换 安装的过程很简单,从oracle官网上下载jdk及jre的rpm包,使用rpm -ivh 安装。但是遇到一个问题,因为fedora系统自带了openJDK,如果安装oracle的jd…

raft算法学习(一):角色概念以及选举过程

Raft算法是强领导模型,集群中只能有一个领导。 下面是raft的视频讲解: raft raft的三种角色及其概念 服务器节点状态一共有三种:领导者(Leader)、跟随着(Follower)、候选人(Candid…

解决 FLex 4.0 Module里面Alert.show();出错问题

TypeError: Error #1009: 无法访问空对象引用的属性或方法。 at mx.managers::PopUpManagerImpl/http://www.adobe.com/2006/flex/mx/internal::createModalWindow()[E:\dev\hero_private\frameworks\projects\framework\src\mx\managers\PopUpManagerImpl.as:701] at mx.manag…

datetime2 数据类型

.net的Entity Framework构建网站数据层,给一个实体的DATETIME类型的属性赋值时 突然莫名奇妙显示有一个类型不匹配的异常如下: System.Data.SqlClient.SqlException: 从 datetime2 数据类型到 datetime 数据类型的转换产生一个超出范围的值。 解决方法&a…

Yslow的A评级指南

这里测的是V2引擎,V1想拿A几乎不可能,一个CDN测试的F就可以轻松废了你的网站。 A评级 现在一个一个分析。 User fewer HTTP Requests:减少HTTP请求 图片、CSS、JS、flash等这些都需要增加http请求数,减少这些元素的数量能减少响应…

jquery下 选择器整理

jQuery 的选择器可谓之强大无比,这里简单地总结一下常用的元素查找方法 $("#myELement") 选择id值等于myElement的元素,id值不能重复在文档中只能有一个id值是myElement所以得到的是唯一的元素 $("div") 选择所有的di…

git日常使用教程

目录git日常使用git 基础用法(本地)git branchgit checkoutgit mergegit rebaseHEAD ,在提交树上移动相对引用强制修改分支位置撤销变更整理提交记录提交技巧Git TagsGit Describegit 基础用法(远程)git fetchgit pullgit push偏离的提交历史,十分重要!&…

android一键分享功能不使用任何第三方sdk

在android中有自带的一键分享功能,不过它会把所有带分享的应用都找出来,如果我们只需要一些常见的分享应用,该如何做呢? 下面看我的效果图(横屏和竖屏自动适配): 接下来看我的调用(支…

包含EditText组件的界面中,禁止自动弹出软键盘

解决方法: 1)在Manifest.xml文件中相应的activity下添加一下代码:android:windowSoftInputMode"stateHidden"2)让EditText失去焦点,使用EditText的clearFocus方法 例如:EditText edit(EditText)f…