架构定义 | 青训营笔记

27 阅读3分钟

这是我参与「第五届青训营 」笔记创作活动的第4天

虽然有些对不起老师,但学校老师在课上讲的架构确实是太浅太小了,以至于很大一部分学生到毕业都只知道MVC。而且在我看来,如今MVC比起架构,更应该说是一种模式。

架构的定义

  • 是有关软件整体结构与组件的抽象描述
  • 用于指导软件系统各个方面的设计

架构实际上对于实现软件的方法选择上起着至关重要的指导作用。

架构的演进

单机

最简单的架构,所有功能在一个进程,并部署在一台机器上。

优点:

  • 简单

问题:

  • C10K problem(性能瓶颈)
  • 运维需要停服

单体、垂直应用|垂直切分

把整个系统垂直切分成多个工作模块,每个工作模块独立完成某一个完整的工作。引入一个统一管理器来管理。每个工作模块还可以进一步拆分成几个工作模块,能够分工协作。

优点:

  • 水平扩容
  • 运维不需要停服

问题:

  • 职责太多,开发效率不高
  • 爆炸半径大

SOA(Service-Oriented Architecture)、微服务|水平切分

将应用的不同功能单元抽象为服务,定义服务之间的通信标准。微服务架构是SOA的去中心化演进方向,提倡服务之间的自由配合。

问题:

  • 数据一致性
  • 高可用
  • 治理
  • 解耦 vs 过微

垂直切分,意味着每个工作单元都能够独立完成完整的工作。而水平切分是将完整的工作单元拆分成几个部分(服务),每个部分负责完成工作的某一部分,这样做到了进一步的解耦,不同的服务之间也能够随意组合实现不同的功能。

企业级后端架构

随着用户、业务的增加,业务逻辑越来越复杂,自然也带来了更多的问题。

云计算

云计算:是指通过软件自动化管理,提供计算资源的服务网络

基础:

  • 虚拟化技术 - 在一台机器上虚拟出来多个机器
  • 编排方案 - 服务商方面 架构:
  • IaaS(Infrastructure as a Service)
    • 买服务器还是租服务器
  • PaaS(Platform as a Service)
    • 自己维护还是托管维护
  • SaaS(Software as a Service)
    • 是否使用现成的软件功能
  • FaaS(Function as a Service)
    • 把应用的逻辑层放到云上运行,所有资源的调度和事件的驱动交给云函数

云原生

  • 弹性资源
    • 虚拟化容器
    • 快速扩缩容
  • 微服务架构
    • 业务功能单元解耦
    • 统一的通信标准
  • DevOps
    • 敏捷开发
    • CI/CD
  • 服务网格
    • 业务与治理解耦
    • 异构系统的治理统一化
    • 复杂治理能力

结语

目前的云计算、云原生等技术方向,对底层进行了进一步的封装,通过把基本硬件的运维工作外包给服务商来进一步解放生产力,让开发人员能够更多地集中精力于业务逻辑的编写上。对我而言,对于云函数这类serverless的服务还是知之甚少,可能一步步在服务器上搭建服务更加具体易懂一些。之后我会更多地尝试新兴的云服务,迎接未来的趋势。