《从零开始学架构》读书笔记(一)

目录

软件架构设计产生的历史背景

软件架构设计的目的

系统复杂度来源

追求高性能

一、单机高性能

二、集群的高性能

追求高可用

一、计算高可用

二、存储高可用

追求可扩展性

一、预测变化

二、应对变化

追求安全、低成本、规模

一、安全

二、低成本

三、规模

读书小结


前言

        作为后端开发攻城狮,学习并掌握一些架构的思想和技能是很有必要的。

        《从零开始学架构》的作者李运华,资深技术专家。这本书是他从业十多年,对架构设计的心得和方法论的总结,比较系统化也比较通俗易懂;正如他在书中开篇提到的,照着做,你也能成为架构师。这很接地气,也正是吸引我的地方。我打算按照读书的进度,记录和总结书中的主要内容,再结合我的理解,整理成几篇读书笔记,定时更新。

软件架构设计产生的历史背景

        软件架构概括成一句话:系统的组织形式、内部联系和逻辑。

        最早在60年代,就已经出现“软件架构”这个概念了,但真正流行却是从90年代开始的,这要从2次软件危机说起:

        第一次软件危机与结构化程序设计(60年代~70年代),这次危机的根源在于软件的“逻辑”变得非常复杂,这次危机催生了结构化程序设计方法结构化程序方法成为了 70年代软件开发的潮流。

        第二次软件危机与面向对象(80年代),这次危机主要体现在软件的“扩展”变得非常复杂,这次危机,促进了面向对象的发展,80年代开始面向对象成为主流的开发思想。

        90年代,人们对软件架构的研究发现:随着软件系统规模的增加,计算相关的算法和数据结构不再构成主要的设计问题;当系统由许多部分组成时,整个系统的组织,也就是所说的“软件架构”,导致了一系列新的设计问题。这样很好解释了在一些大规模的软件开发中,非常容易面临的问题,如系统规模庞大,内部耦合严重,续修改和扩展困难;系统逻辑复杂,出问题后很难排查和修复。

        70年代的危机主要是逻辑复杂问题,结构化编程可以解决这问题,创造了“模块”概念;80年代的危机主要是软件扩展问题,面向对象思想可以解决这问题,创造了“对象”;90年代的“软件架构”开始流行,创造了“组件”概念。我们可以看到,“模块”“对象”“组件”本质上都是对达到一定规模的软件进行拆分,差别只是在于随着软件的复杂度不断增加,拆分的粒度越来越粗,拆分的层次越来越高。

软件架构设计的目的

        软件架构设计的目的是为了解决软件系统复杂度带来的问题。为什么这么说,从前面的两次软件危机可以看到,随着系统规模、业务需求的不断增长,系统的复杂度(功能、性能、扩展、安全等等统称为复杂度)会不断上升,但上升到一定程度后,会导致现有系统难以继续开发维护。引进架构的设计,就是在系统开发之初,设计可行的架构方案,并在迭代过程,及早的发现可能出现的危机,并针对危机,对软件的架构进行调整优化。

系统复杂度来源

        既然架构设计的目的是解决系统复杂度带来的问题,那就要先了解导致系统复杂度增加的几个主要来源:

追求高性能

一、单机高性能

        单机的局限性明显,主要是通过多进程、多线程的方式,提高单机的的吞吐量。

二、集群的高性能

        单机的性能有限,必须采用机器集群的方式来达到高性能。例如,支付宝和微信这种规模的业务系统,后台系统的机器数量都是万台级别的。

1、任务分配

        任务分配的意思是指每台机器都可以处理完整的业务任务,不同的任务分配到不同的机器上执行。分配器可能是硬件网络设备,也可能是负载均衡软件(例如,Nginx、HAProxy)等,任务分配器需要增加分配算法。一般来说机器数量越多,集群整体的性能越强。

2、任务分解

        如果业务本身也越来越复杂,单纯只通过任务分配的方式来扩展性能,收益会越来越低。可以将其拆分为更多的组成部分,例如微信的后台架构。

        通过这种任务分解的方式,能够把原来大一统但复杂的业务系统,拆分成小而简单但需要多个系统配合的业务系统。为何通过任务分解就能够提升性能呢?

  • 简单的系统更加容易做到高性能

        系统的功能越简单,影响性能的点就越少,就更加容易进行有针对性的优化。而系统很复杂的情况下,首先是比较难以找到关键性能点,因为需要考虑和验证的点太多;其次是即使花费很大力气找到了,修改起来也不容易,因为可能将 A 关键性能点提升了,但却无意中将 B 点的性能降低了,整个系统的性能不但没有提升,还有可能会下降。

  • 可以针对单个任务进行扩展

        当各个逻辑任务分解到独立的子系统后,整个系统的性能瓶颈更加容易发现,而且发现后只需要针对有瓶颈的子系统进行性能优化或者提升,不需要改动整个系统,风险会小很多。

3、任务分解的误区

        既然将一个大一统的系统分解为多个子系统能够提升性能,那是不是划分得越细越好呢?其实不然,这样做性能不仅不会提升,反而还会下降,最主要的原因是如果系统拆分得太细,为了完成某个业务,系统间的调用次数会呈指数级别上升,而系统间的调用通道目前都是通过网络传输的方式,性能远比系统内的函数调用要低得多。因此,任务分解带来的性能收益是有一个度的,并不是任务分解越细越好。

追求高可用

        和之前高性能是一样的,都是通过增加更多机器来达到目的,但其实本质上是有根本区别的:高性能增加机器目的在于“扩展”处理性能;高可用增加机器目的在于“冗余”处理单元。

一、计算高可用

        这里的“计算”指的是业务的逻辑处理。计算有一个特点就是无论在哪台机器上进行计算,同样的算法和输入数据,产出的结果都是一样的,所以将计算从一台机器迁移到另外一台机器,对业务并没有什么影响。

二、存储高可用

        存储高可用的痛点,在于多个数据库或缓存服务器之间,数据不一定时时刻刻是一致的,可能存在某一个时刻数据不一致的问题,例如主从数据库的数据同步可能存在网络延迟。

        按照“数据 + 逻辑 = 业务”这个公式来套的话,数据不一致,即使逻辑一致,最后的业务表现就不一样了。所以存储高可用的难点不在于如何备份数据,而在于如何减少或者规避数据不一致对业务造成的影响

        著名的 CAP 定理,从理论上论证了存储高可用的复杂度。也就是说,存储高可用不可能同时满足“一致性、可用性、分区容错性”,最多满足其中两个。后续的读书笔记中详细展开说明吧。

追求可扩展性

        设计具备良好可扩展性的系统,有两个基本条件:正确预测变化完美封装变化。但要达成这两个条件,本身也是一件复杂的事情。

一、预测变化

        软件系统在发布后还可以不断地修改和演进,这就意味着不断有新的需求需要实现。预测变化的复杂性在于:

  • 不能每个设计点都考虑可扩展性。
  • 不能完全不考虑可扩展性。
  • 所有的预测都存在出错的可能性。
二、应对变化

        第一种应对变化的常见方案是将“变化”封装在一个“变化层”,将不变的部分封装在一个独立的“稳定层”。

  • 系统需要拆分出变化层和稳定层
  • 需要设计变化层和稳定层之间的接口

        第二种常见的应对变化的方案是提炼出一个“抽象层”和一个“实现层”。抽象层是稳定的,实现层可以根据具体业务需要定制开发,当加入新的功能时,只需要增加新的实现,无须修改抽象层,例如设计模式中的策略模式。后续的读书笔记中详细展开说明吧。

追求安全、低成本、规模

一、安全

        从技术的角度来讲,安全可以分为两类:一类是功能上的安全,一类是架构上的安全。

        功能安全其实就是“防小偷”,从实现的角度来看,功能安全更多地是和具体的编码相关。

        架构安全就是“防强盗”,传统的架构安全主要依靠防火墙,防火墙最基本的功能就是隔离网络,通过将网络划分成不同的区域,制定出不同区域之间的访问控制策略来控制不同信任程度区域间传送的数据流。例如DDos攻击防护。

二、低成本

        成本可以简单的分为:机器硬件的成本、第三方软件的成本、人员开发和维护成本等等;

三、规模

        软件规模带来复杂度的主要原因就是“量变引起质变”:

  • 功能越来越多,导致系统复杂度指数级上升
  • 数据越来越多,系统复杂度发生质变

读书小结

        这次读书笔记,我主要分享了软件架构的出现的历史背景,列举了两次软件危机,软件架构设计的目的是为了解决系统复杂度带来的问题,以及系统的复杂度的来源等,下一次《从零开始学架构》读书笔记,我将分享软件架构设计的三个原则、架构设计流程等的读书心得。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

使用 Python 的 LSTM 进行股市预测

目录 一、说明 二、为什么需要时间序列模型? 三、下载数据 3.1 从 Alphavantage 获取数据 3.1 从 Kaggle 获取数据 3.3 数据探索 3.4 数据可视化 四、将数据拆分为训练集和测试集 五、数据标准化 六、通过平均进行一步预测 6.1 标准平均值 6.2 指数移动平均线 6.3 如…

C++类与对象中(个人笔记)

类与对象中 类的6个默认成员函数1.构造函数1.1特性 2.析构函数2.1特性 3.拷贝构造函数3.1特性 4.赋值运算符重载4.1特性 5.日期类的实现6.const成员6.1const成员的几个问题 7.取地址及const取地址操作符重载 类的6个默认成员函数 如果一个类中什么成员都没有,简称为…

iOS 17.5系统或可识别并禁用未知跟踪器,苹果Find My技术应用越来越合理

苹果公司去年与谷歌合作,宣布将制定新的行业标准来解决人们日益关注的跟踪器隐私问题。苹果计划在即将发布的 iOS 17.5 系统中加入这项提升用户隐私保护的新功能。 科技网站 9to5Mac 在苹果发布的 iOS 17.5 开发者测试版内部代码中发现了这项反跟踪功能的蛛丝马迹…

SAP HCM PT 2003修改班次,PP61无法自动更新

今天遇到一个问题,2003修改班次以后PP61无法自动更新,开始一直以为是什么配置点漏掉,但是发现开发机没问题,后来发现是用户选保存的时候选中目标计划的完成,这个是保存到实际计划的,数据存储psoll中&#x…

引入精益管理方式,需要提前做到这九点

​ 近年来,软件项目的规模及其复杂性正在以空前的速度增长,互联网用户市场庞大,互联网公司和相应的软件产品层出不穷。快速响应需求变化往往是互联网行业的常态,软件产品的快速开发迭代对于公司迅速占领市场、抢占商机有着举足轻重…

js通过Object.defineProperty实现数据响应式

目录 数据响应式属性描述符propertyResponsive 依赖收集依赖队列寻找依赖 观察器 派发更新Observer完整代码关于数据响应式关于Object.defineProperty的限制 数据响应式 假设我们现在有这么一个页面 <!DOCTYPE html> <html lang"en"><head><m…

ics-05-攻防世界

题目 点了半天只有设备维护中心能进去 御剑扫一下 找到一个css 没什么用 再点击云平台设备维护中心url发生了变化 设备维护中心http://61.147.171.105:65103/index.php?pageindex试一下php伪协议 php://filter/readconvert.base64-encode/resourceindex.php base64解一下…

python 指数搜索(Exponential Search)

该搜索算法的名称可能会产生误导&#xff0c;因为它的工作时间为 O(Log n)。该名称来自于它搜索元素的方式。 给定一个已排序的数组和要 搜索的元素 x&#xff0c;找到 x 在数组中的位置。 输入&#xff1a;arr[] {10, 20, 40, 45, 55} x 45 输出&#xff1a;在索…

打包与发布iOS应用的完整指南

摘要 本文旨在指导开发者如何准备工作、打包和发布iOS应用。详细介绍了生成请求证书文件、生成APP开发证书及发布证书、生成APP ID、添加调试设备、生成描述文件等步骤。同时&#xff0c;结合案例演示和实际操作&#xff0c;帮助读者更好地理解和应用这些步骤。通过本文&#…

34470A是德科技34470A数字万用表

181/2461/8938产品概述&#xff1a; Truevolt数字万用表&#xff08;34460A、34461A、34465A、34470A&#xff09;利用是德科技的新专利技术&#xff0c;使您能够快速获得见解、测量低功耗设备并保持校准的测量结果。Truevolt提供全方位的测量能力&#xff0c;具有更高的精度、…

基于51单片机教室灯光全自动控制设计( proteus仿真+程序+设计报告+原理图+讲解视频)

基于51单片机教室灯光全自动控制设计( proteus仿真程序设计报告原理图讲解视频&#xff09; 基于51单片机教室灯光全自动控制设计 1. 主要功能&#xff1a;2. 讲解视频&#xff1a;3. 仿真设计4. 程序代码5. 设计报告6. 原理图7. 设计资料内容清单&&下载链接 仿真图pro…

Python | NCL风格 | EOF | 相关 | 回归

这里在linux系统上使用geocat实现NCL风格的图片绘制 Linux上安装 geocat conda update conda conda create -n geocat -c conda-forge geocat-viz conda activate geocat conda update geocat-vizDataset - NOAA Optimum Interpolation (OI) SST V2 # 海温月平均数据 - lsmas…

dubbo知识点

为什么要用 Dubbo&#xff1f; 随着服务化的进一步发展&#xff0c;服务越来越多&#xff0c;服务之间的调用和依赖关系也越来越复杂&#xff0c;诞生了面向服务的架构体系(SOA)&#xff0c;也因此衍生出了一系列相应的技术&#xff0c;如对服务提供、服务调用、连接处理、通信…

React - 你使用过高阶组件吗

难度级别:初级及以上 提问概率:55% 高阶组件并不能单纯的说它是一个函数,或是一个组件,在React中,函数也可以做为一种组件。而高阶组件就是将一个组件做为入参,被传入一个函数或者组件中,经过一定的加工处理,最终再返回一个组件的组合…

海外仓的痛点和需求都有哪些?位像素海外仓系统能解决什么问题?

在全球化贸易的时代&#xff0c;越来越多人将目光聚焦在海外仓上&#xff0c;下场想要分一杯羹。然而&#xff0c;海外仓管理过程中也存在着许多痛点和挑战。为此&#xff0c;海外仓都会使用海外仓系统来协助管理海外仓。来探讨一下海外仓的痛点、需求以及海外仓系统能够解决的…

TiDB 慢查询日志分析

导读 TiDB 中的慢查询日志是一项 关键的性能监控工具&#xff0c;其主要作用在于协助数据库管理员追踪执行时间较长的 SQL 查询语句。 通过记录那些超过设定阈值的查询&#xff0c;慢查询日志为性能优化提供了关键的线索&#xff0c;有助于发现潜在的性能瓶颈&#xff0c;优化…

XML HTTP传输 小结

what’s XML XML 指可扩展标记语言&#xff08;eXtensible Markup Language&#xff09;。 XML 被设计用来传输和存储数据&#xff0c;不用于表现和展示数据&#xff0c;HTML 则用来表现数据。 XML 是独立于软件和硬件的信息传输工具。 应该掌握的基础知识 HTMLJavaScript…

跨越网络边界:借助C++编写的下载器程序,轻松获取Amazon商品信息

背景介绍 在数字化时代&#xff0c;数据是新的石油。企业和开发者都在寻找高效的方法来收集和分析网络上的信息。亚马逊&#xff0c;作为全球最大的电子商务平台之一&#xff0c;拥有丰富的商品信息&#xff0c;这对于市场分析和竞争情报来说是一个宝贵的资源。 问题陈述 然…

相机标定——四个坐标系介绍

世界坐标系(Xw,Yw,Zw) 世界坐标系是一个用于描述和定位三维空间中物体位置的坐标系&#xff0c;通常反映真实世界下物体的位置和方向。它是一个惯性坐标系&#xff0c;被用作整个场景或系统的参考框架。在很多情况下&#xff0c;世界坐标系被认为是固定不变的&#xff0c;即它…

Windows系统配置Docker的国内镜像

1.打开docker的设置&#xff0c;点击Docker Engine 2.添加国内的镜像源&#xff0c;将下面的内容加进去 "registry-mirrors": ["https://docker.mirrors.ustc.edu.cn","https://registry.docker-cn.com","http://hub-mirror.c.163.com&quo…