Go 语言架构 | 青训营笔记

132 阅读2分钟

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

本文为青训营课程笔记,配合原课程食用效果更佳哦~

课程笔记

架构的定义

架构,又被称为软件架构

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

简单来说就是:实现一个软件有很多种方法,而架构在方法选择上、起着至关重要的指导作用

架构的重要性

举个比喻

  • 地基没打好,大厦容易倒
  • 地基坚实了,大厦才能盖得高
  • 站在巨人肩膀上,才能看得远

有哪些架构

单体架构

软件系统需要具备对外提供服务,单机,就是把所有功

能都实现在一个进程里,并部署在一台机器上

优点:

  • 简单

问题:

  • C10K problem
  • 运维需要停服
垂直应用架构

单体架构:分布式部署

垂直应用架构:按应用垂直切分

的单体

优点:

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

问题:

  • 职责太多,开发效率不高
  • 爆炸半径大
微服务架构

SOA* (Service-Oriented Architecture)*

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

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

微服务架构:SOA 的去中心化演进方向

问题:

  • 数据一致性
  • 装货台共交付了多少蛋糕?
  • 高可用
  • 这么多师傅,如何合作?
  • 治理
  • 烤箱坏了,怎么容灾?
  • 解耦 vs 过微
  • 运维成本高了,值当么?

架构小结

架构的演进初衷:好比做蛋糕。

  • 需求量越来越大,终归要增加人手
  • 越做越复杂,终归要分工合作

架构的演进思路:程序就像切蛋糕。蛋糕越来越大,一口吃不下终归要切分

  • 竖着切(垂直切分)垂直架构
  • 横着切(水平切分)微服务架构

总结收获

通过样例与知识点结合的方式,学到了一些架构相关知识;

通过样例的讲解,更了解了具体的架构划分方法;

又是收获满满的一天

引用参考

青训营课程课件

青训营课程视频