架构 | 青训营笔记

91 阅读3分钟

这是我参与【第五届青训营】伴学笔记创作活动的第10天

团队规模和流程的关系

需求 ——————> 开发 ——————> 测试 ——————> 发布 ——————> 运维

1、架构

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

单机架构

软件系统需要具备对外提供服务,单机,就是把所有功能都实现在一个进程里,并部署在一台机器上。

优点:

  • 简单

缺点:

  • 运维需要停服,用户体验较差
  • 承载能力有限,了解下 c10k 问题

单体架构

在单机架构的基础上,将进程部署到多个机器上。

优点:

  • 具备水平扩容能力
  • 运维不需要停服

缺点:

  • 后端进程职责太多,越来越臃肿
  • 爆炸半径较大,进程中一个很小的模块出现问题,都可能导致整个进程崩溃

垂直应用架构

在单机架构基础上,将进程按照某种依据切分开。比如,A 软件和 B 软件的后端原先采用单机架构部署,那就是一个进程部署在多个机器上;如果用垂直应用架构,可以将 A 和 B 的后端拆分为 A、B 两个进程,然后再按照单体模式的思路,部署在多个机器上。

优点:

  • 一定程度上减少了后端进程职责
  • 一定程度上缩小爆炸半径

缺点:

  • 没有根本解决单体架构的问题

SOA (面向服务架构)

SOA

1、将应用的不同功能单元抽象为服务

2、定义服务之间的通信标准

优点:

  • 各服务的职责更清晰
  • 运维粒度减小到服务,爆炸半径可控

缺点:

  • ESB (企业服务总线) 往往需要一整套解决方案

微服务

在 SOA 架构中,ESB 起到了至关重要的作用。但从架构拓扑来看,它更像是一个集中式的模块。有一个 SOA 分布式演进的分支,最终的形态便是微服务。

优点:

  • 兼具 SOA 解决的问题
  • 服务间的通信更敏捷、灵活

缺点:

  • 运维成本

2、企业级后端架构剖析

云计算

基础:

  • 虚拟化技术

    • 硬件层面(VM 虚拟机)- KVM/Xen/VMware
    • 操作系统层面(Container 容器)- LCX/Docker/Kata Container
    • 网络层面 - Linux Bridge/Open v Switch
  • 编排方案

    • VM - OpenStack/VMWare Workstation
    • Container - Kubernetes/Docker Swarm

云计算架构:

  • 云服务

    • IaaS - 云基础设施,对底层硬件资源池的抽象
    • PaaS - 基于资源池抽象,对上层提供的弹性资源平台
    • SaaS - 基于弹性资源平台构建的云服务
    • FaaS - 更轻量级的函数服务。好比 LeetCode 等 OJ,刷题时只需要实现函数,不需要关注输入输出流
  • 云部署模式(拓展)

    • 私有云 - 企业自用

    • 公有云 - AWS/Azure/Google Cloud/Huawei

    • 混合云

云原生

实际是云原生(计算)的简称,它是云计算发展到现在的一种形态。

云原生技术为组织(公司)在公有云、自由云、混合云等新型的动态环境中,构建和运行可弹性拓展的应用提供了可能。 它的代表技术:

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

课程学习链接

juejin.cn/course/byte…

juejin.cn/course/byte…

juejin.cn/course/byte…

juejin.cn/course/byte…