互联网应用的架构演变之路

简介: 随着互联网的发展,网站的应用也不断扩大,从而导致系统架构不断的进行变化,从互联网早起到现在,系统架构大致经历了下面几个过程。

随着互联网的发展,网站的应用也不断扩大,从而导致系统架构不断的进行变化,从互联网早起到现在,系统架构大致经历了下面几个过程。

在这里插入图片描述

单体应用架构

所有功能都集中在一个应用中,统一开发、部署、维护。

  • 优点:开发成本、部署成本、维护成本低
  • 缺点:对于大型项目来说,项目模块紧密耦合、单点容错率低、无法针对某一个模块优化和水平扩展。

垂直应用架构

将之前的单体应用拆分成多个应用,提升效率。比如,电商系统可以拆分成电商系统、后台系统等。

  • 优点:项目拆分实现流量分担,解决并发问题,可以针对某一个模块优化和水平扩展,同时应用之间不会相互影响,提高容错率。
  • 缺点:应用相互存在又是独立的,对于相同的功能会造成一定的冗余。

分布式架构

随着业务的增加,在垂直应用中的冗余代码会越来越多。将冗余代码抽取出来单独的服务提供应用调用形成分布式架构。

  • 优点:抽取公共的功能作为服务层,提高代码复用。
  • 缺点:系统间耦合变高,调用关系错综复杂,难以维护。

SOA架构

分布式架构的缺点就是应用和服务之间调用复杂,难以维护,尤其是当服务节点越来越多的时候。SOA就是为了解决资源调度和治理的问题。

  • 优点:使用治理中心(ESB/Dubbo)解决服务间调用关系的自动调节。
  • 缺点:服务间有依赖关系,某一环节出现问题影响较大。

微服务架构

某种程度上SOA架构发展的下一步,微服务架构更加强调服务的拆分,每个服务独立部署互不影响,更加轻巧、轻量级。

  • 优点:服务独立打包部署和升级,功能划分清晰,利于扩展。
  • 缺点:成本高、复杂度高。

SOA架构&微服务架构对比

  • 微服务架构更加精细,专业的人做专业的事。
  • 微服务架构中,每个服务独立部署。
  • 微服务架构中,每个服务都是单独的数据库。
  • 微服务架构更加适合互联网敏捷开发、快速迭代版本。

分布式应用开发解决方案

Spring Cloud提供微服务开发的一站式解决方案,包含开发分布式应用微服务的必须组件,方便开发者通过Spring Cloud编程模型轻松开发分布式应用服务。目前Spring Cloud生态有Spring Cloud Netflix、Spring Cloud Alibaba两套框架。

相关文章
|
3月前
|
设计模式 前端开发 数据库
从MVC到MVVC:软件架构的演变和迭代(二)
从MVC到MVVC:软件架构的演变和迭代
|
5月前
|
XML 数据库 数据格式
微服务技术系列教程(15) - SpringCloud - 互联网网站架构演变过程
微服务技术系列教程(15) - SpringCloud - 互联网网站架构演变过程
41 0
|
1月前
|
存储 分布式计算 Hadoop
带你了解文件系统架构的演变:从传统到分布式
带你了解文件系统架构的演变:从传统到分布式
83 0
|
1月前
|
存储 数据安全/隐私保护 云计算
带你了解文件系统架构的演变:从传统到分布式
带你了解文件系统架构的演变:从传统到分布式
79 0
|
3月前
|
设计模式 监控 前端开发
从MVC到MVVC:软件架构的演变和迭代(一)
从MVC到MVVC:软件架构的演变和迭代
|
4月前
|
存储 网络协议 Dubbo
Rpc编程系列文章第一篇:RPC概述和架构演变
Rpc编程系列文章第一篇:RPC概述和架构演变
|
6月前
|
Dubbo Java 应用服务中间件
09分布式电商项目 - SOA架构演变
09分布式电商项目 - SOA架构演变
80 0
|
7月前
|
XML 网络协议 Java
SOA系统架构的演变
SOA系统架构的演变
75 0
|
8月前
|
负载均衡 应用服务中间件 微服务
从单体架构到分布式架构的演变--新手向
单体架构到分布式架构更多的是从项目的系统架构层面进行的讨论,故不要将单体架构与业务分层(如mapper、dao、controller……)相混淆 本文将以一个简单的商城项目为导引,讲解单体架构与分布式架构 项目包含了订单模块、用户模块、支付模块和商品模块等
135 0