软考高级架构 —— 10.6 大型网站系统架构演化实例 + 软件架构维护

10.6 大型网站系统架构演化实例

        大型网站的技术挑战主要来自于庞大的用户,高并发的访问和海量的数据,主要解决这类问题。        

1. 单体架构

  • 特点: 所有资源(应用程序、数据库、文件)集中在一台服务器上。
  • 适用场景: 小型网站,用户和数据量较少。
  • 限制: 随用户增长,性能和存储空间成为瓶颈。

2. 垂直架构

  • 优化: 应用程序与数据分离,分为应用服务器、文件服务器、数据库服务器。
  • 优势:
    • 根据不同需求优化硬件配置(CPU、内存、硬盘)。
    • 数据存储和业务处理能力提升。
  • 挑战: 数据库压力依然会随着用户增长增加。

3. 引入缓存

  • 原因: 数据访问遵循“二八定律”,80%的访问集中在20%的数据。
  • 方法:
    • 本地缓存:快速但受服务器内存限制。
    • 远程分布式缓存:支持大规模缓存,性能更稳定。
  • 效果: 缓解数据库访问压力,但应用服务器连接数有限,成为瓶颈。

4. 应用服务器集群

  • 解决方案: 使用负载均衡器,将用户请求分配到多个应用服务器。
  • 优势:
    • 通过横向扩展增加服务器,提升系统可伸缩性。
    • 不依赖更强大的单台服务器。

5. 数据库读写分离

  • 问题: 写操作和部分读操作仍集中在主数据库,负载高。
  • 优化:
    • 主数据库负责写操作。
    • 从数据库通过主从复制承担读操作。
    • 数据访问模块实现透明的读写分离。
  • 效果: 数据库性能进一步提升。

6. 反向代理与 CDN

  • 目标: 缓解因区域网络差异导致的访问延迟问题。
  • 方法:
    • CDN: 部署在网络提供商机房,用户从最近位置获取内容。
    • 反向代理: 缓存服务器,用户请求优先访问代理缓存内容。
  • 效果: 提升响应速度,降低后端服务器负载。

7. 分布式文件与数据库

  • 问题: 单一数据库或文件服务器无法满足持续增长需求。
  • 解决方案:
    • 分布式文件系统: 将文件分布在多个服务器上。
    • 分布式数据库: 拆分业务数据库,减少单表数据规模。
  • 效果: 支持海量数据存储与高并发访问。

8. 引入 NoSQL 与搜索引擎

  • 原因: 数据结构复杂,传统关系型数据库难以满足需求。
  • 优化:
    • NoSQL: 提供分布式、弹性的数据存储。
    • 搜索引擎: 加速复杂数据检索。
  • 效果: 更灵活的数据存储与查询能力。

9. 业务拆分

  • 目标: 按产品线拆分网站(如首页、订单、用户等)。
  • 方法:
    • 每个产品线独立部署为单独应用。
    • 应用间通过消息队列或共享数据存储系统通信。
  • 效果: 降低单一应用复杂度,提高团队开发效率。

10. 分布式服务化

  • 挑战: 应用复杂度增高,维护成本增加。
  • 解决方案:
    • 提取共用业务逻辑为分布式服务(如用户管理、订单管理)。
    • 应用通过服务调用完成具体操作。
  • 效果: 简化应用间依赖关系,提升开发与运维效率。

10.7 软件架构维护

  1. 架构知识管理

    • 定义:包含架构设计和设计决策,用于解释架构方案的选择原因。
    • 目标:确保关键设计知识不会因人员流失或变更而丢失,支持架构的演化和长期可维护性。
    • 现状:架构知识文档化实践较少,主要由于动机不足、文档维护成本高等问题。
  2. 架构修改管理

    • 建立隔离区域以最小化修改影响,明确修改规则和类型。
    • 追踪修改的副作用和影响范围,提升修改过程的可靠性。
  3. 架构版本管理

    • 提供演化控制和度量基础,支持静态与动态演化分析。
    • 利用矩阵方法分析架构演化的波及效应,量化组件的贡献和影响。
  4. 架构可维护性度量

    • 圈复杂度(CCN):衡量架构复杂程度,用于早期风险评估,推荐值≤10。
    • 扇入扇出度(FFC):表示模块与其他模块的交互频率,高值表明模块关联密集。
    • 模块间耦合度(CBO):评估模块依赖关系的程度,高耦合模块维护风险高。
    • 模块响应度(RFC):衡量模块提供的功能数量及其复杂性。
    • 紧内聚度(TCC) 和松内聚度(LCC):表示模块内部组件的协作程度,评估模块内聚性。

评估方法与结果

  • 将系统组件图导出为数据文件(如XML),利用架构评估工具计算各项指标。
  • 示例系统的计算结果显示:
    • 高度关联的模块(如RSApplication)FFC和CBO较高,维护风险较大。
    • 独立模块(如UserDB)度量值较低,复杂性和耦合程度较小。
    • 组件内聚性仅适用于包含子模块的组件,如ClientApplication

建议与实践

  1. 文档化和知识管理

    • 推动团队建立有效的架构知识管理机制,使用工具化手段记录设计决策。
    • 定期复盘设计决策的长期影响,提升架构演化的可预测性。
  2. 自动化与工具支持

    • 应用架构评估工具(如MSAES)自动化度量指标计算,减少人工误差。
    • 在设计初期及演化关键点评估CCN、CBO等指标,指导后续优化。
  3. 培训与意识提升

    • 强化团队成员对架构知识记录和分享重要性的理解。
    • 鼓励在开发过程中注重长远可维护性而非短期利益。

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

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

相关文章

Golang囊地鼠gopher

开发知识点-golang 介绍红队专题-Golang工具Fscan简介主要功能ubuntu 安装windows 安装常用命令:项目框架源文件common目录Plugins目录Webscan目录入口点插件扫描类型爆破插件common.ScantypeWebtitle函数webpoc扫描POC 执行CEL-GO 实践CEL指纹识别免杀源码特征参考链接红队专…

多分类交叉熵与稀疏分类交叉熵

总结: 标签为 One-hot 编码的多分类问题,用分类交叉熵对于标签为整数的多分类问题,用稀疏分类交叉熵稀疏分类交叉熵内部会将整数标签转换为 One-hot 编码,而如果标签已经是 One-hot 编码的形式,再使用稀疏分类交叉熵就会多此一举。 算例 假设我们有三个类别:A、B 和 C。…

360极速浏览器不支持看PDF

360安全浏览器采用的是基于IE内核和Chrome内核的双核浏览器。360极速浏览器是源自Chromium开源项目的浏览器,不但完美融合了IE内核引擎,而且实现了双核引擎的无缝切换。因此在速度上,360极速浏览器的极速体验感更佳。 展示自己的时候要在有优…

零基础微信小程序开发——小程序的宿主环境(保姆级教程+超详细)

🎥 作者简介: CSDN\阿里云\腾讯云\华为云开发社区优质创作者,专注分享大数据、Python、数据库、人工智能等领域的优质内容 🌸个人主页: 长风清留杨的博客 🍃形式准则: 无论成就大小,…

麒麟信安推出支持信创PC的新一代云桌面方案,助力政务信创高效安全运维

12月11日,在第二届国家新一代自主安全计算系统产业集群融通生态大会上,麒麟信安发布了支持信创PC的新一代云桌面方案,该方案是基于国际TCI架构实现国产PC机云化纳管在国内的首次发布,并与银河麒麟桌面操作系统、长城国产PC整机实现…

vim优化

1.编辑如下内容&#xff1a; cat > /root/.vimrc <<EOF set tabstop2 " 设置 Tab 为 2 个空格 set shiftwidth2 " 设置自动缩进为 2 个空格 set expandtab " 将 Tab 转换为空格 " 基本设置 set number syntax on" 快捷键设置…

hive—常用的日期函数

目录 1、current_date 当前日期 2、now() 或 current_timestamp() 当前时间 3、datediff(endDate, startDate) 计算日期相差天数 4、months_between(endDate, startDate) 日期相差月数 5、date_add(startDate, numDays) 日期加N天 6、date_sub(startDate, numDays) 日期减…

医学分割数据集肾结石分割数据集labelme格式359张1类别

数据集格式&#xff1a;labelme格式(不包含mask文件&#xff0c;仅仅包含jpg图片和对应的json文件) 图片数量(jpg文件个数)&#xff1a;359 标注数量(json文件个数)&#xff1a;359 标注类别数&#xff1a;1 标注类别名称:["kidney stone"] 每个类别标注的框数&…

Vulnstack红日安全内网域渗透靶场2实战攻略

一&#xff1a;环境搭建 新增的网卡VMnet2&#xff0c;ip调成10段。 PC配置如下&#xff1a; DC在该环境中充当是域控。DC配置如下 &#xff1a; WEB配置&#xff1a;需要两块网卡&#xff0c;相当于网关服务器。 作者把外网网段都写成了192.168.111.1/24&#xff0c;我们可以…

基础库urllib的使用

学习爬虫&#xff0c;其基本的操作便是模拟浏览器向服务器发出请求&#xff0c;那么我们需要从哪个地方做起呢?请求需要我们自己构造吗?我们需要关心请求这个数据结构怎么实现吗?需要了解 HTTP、TCP、IP层的网络传输通信吗?需要知道服务器如何响应以及响应的原理吗? 可能…

【大数据技术基础】【记录Ubuntu 16.04升级到18.04】Ubuntu的一个版本升级到另一个版本

在 Ubuntu 操作系统中进行软件更新和系统升级 Ubuntu Kylin 16.04 LTS 系统进行系统升级到 Ubuntu 18.04.6 LTS 版本 升级提示&#xff1a;系统弹出提示框&#xff0c;告知用户有新版本的 Ubuntu 可用&#xff0c;询问用户是否想要升级。 认证窗口&#xff1a;显示了一个认证…

【环境搭建】Python、PyTorch与cuda的版本对应表

一个愿意伫立在巨人肩膀上的农民...... 在深度学习的世界里&#xff0c;选择合适的工具版本是项目成功的关键。CUDA、PyTorch和Python作为深度学习的三大支柱&#xff0c;它们的版本匹配问题不容忽视。错误的版本组合可能导致兼容性问题、性能下降甚至项目失败。因此&#xff0…

SpringBoot 学习

SpringBoot 学习 什么是 Springboot Spring Boot 是 Spring 提供的一个子项目&#xff0c;用于快速构建 Spring 应用程序 传统的问题&#xff1a; 导入依赖繁琐项目配置繁琐 SpringBoot 的特性 起步依赖&#xff1a;整合所有 web 的依赖配置好了自动配置&#xff1a;bean…

计算机网络-传输层 TCP协议(下)

目录 TCP核心机制五&#xff1a;流量控制 TCP核心机制六&#xff1a;拥塞控制 TCP核心机制七&#xff1a;延迟应答 TCP核心机制八&#xff1a;捎带应答 TCP核心机制九&#xff1a;面向字节流 粘包问题 TCP核心机制十&#xff1a;异常处理 &#xff08;1&#xff09;进程…

【游戏设计原理】10 - 科斯特的游戏理论

科斯特的游戏理论强调了游戏与学习之间的关系&#xff0c;认为“玩得开心”与“学习”是紧密相连的。换句话说&#xff0c;游戏的核心魅力在于通过适当的挑战和不断的学习进程激发玩家的内啡肽循环&#xff0c;这让玩家在不断的探索和进步中找到乐趣。 科斯特的理论通过游戏是…

【Android学习】RxJava

文章目录 资料连接1. Merge & Zip操作符: 合并数据源2. Map & FlapMap & ConcatMap & Buffer: 变换操作符3. retry & retryUntil & retryWhen : 错误处理操作符4. Transformer & Compose 转换符 资料连接 Android RxJava&#xff1a; 这是一份全面…

数据结构初阶---二叉树---堆

一、树 1.树的概念 树是一种非线性的数据结构&#xff0c;由n(n≥0)个有限结点组成的一个有层次关系的集合。形状类似一棵倒挂的树&#xff0c;根朝上&#xff0c;分支向下。 根结点没有前驱结点&#xff0c;可以有n(n≥0)个后继结点。 其余结点被分为M个互不相交的集合&am…

高等动力学中的正则变换

1 正则变化的定义 在相空间中&#xff0c;如果以时间t为参数的坐标变换 使得满足哈密顿正则方程 的动力变量 和 变成满足新的正则方程 的新的动力变量 和 &#xff0c;则称该变换为正则变换。 该变换可逆的条件&#xff1a;雅可比行列式值不等于零 正则变换的充要条件&#…

在线图片格式转换器 - 加菲工具

图片格式转换器-加菲工具 支持JPG\JPGE\PNG\ICO\BMP之间相互转换。 打开加菲工具或者直接打开 https://www.orcc.online/tools/image 选择“图片格式转换器” 上传图片&#xff0c;选择目标格式 转换完成

python web练习案例:基于表单类的商品管理(修改并删除商品信息)

目录 1、修改商品信息 &#xff08;1&#xff09;修改show.html页面&#xff0c;增加 修改 栏 &#xff08;2&#xff09;创建 update.html 网页&#xff0c;继承 add.html 模板 &#xff08;3&#xff09;定义视图函数 &#xff08;4&#xff09;定义路由 (5) 浏览器查看 …