大型网站技术架构 核心原理与案例分析 读后日志

大型网站技术架构 核心原理与案例分析 读后总结

  • 概述
    • 大型网站架构演化
    1. 大型网站软件系统的特点
  1. 高并发、大流量
  2. 高可用
  3. 海量数据
  4. 用户分布广泛,网络情况复杂
  5. 安全环境恶劣
  6. 需求快速变更,发布频繁
  7. 渐进式发展
    1. 大型网站架构演化发展历程
      1. 初始阶段的网站架构:大型网站都是从小型网站发展而来
      2. 应用服务和数据服务分离
      3. 使用缓存改善网站性能
      4. 使用应用服务器集群改善网站的并发处理能力
      5. 数据库读写分离
      6. 使用反向代理和CDN加速网站响应:
  1. CDN部署在网络提供商的机房,使用户在请求网站服务时可以从距离自己最近的网络提供商机房获取数据。
  2. 反向代理部署在网站的中心机房,当用户请求到达中心机房后,首先访问的服务器是反向代理服务器,如果反向代理服务器中缓存着用户请求的资源,就将其直接返回给用户。
      1. 使用分布式文件系统和分布式数据库系统
      2. 使用NoSQL和搜索引擎
      3. 业务拆分
      4. 分布式服务
    1. 大型网站架构演化的价值
      1. 大型网站架构技术的核心价值是随网站所需灵活应对
      2. 大型网站技术发展的主要力量是网站的业务发展
    2. 网站架构设计误区
      1. 一味追随大公司的解决方案
      2. 为了技术而技术
      3. 企图用技术解决所有问题
    • 大型网站架构模式
  1. 网站架构模式:
    • 分层

应用层

负责具体业务和视图展示,如网站首页及搜索输入和结果展示。

服务层

为应用层提供服务支持,如用户管理服务,购物车服务等。

数据层

提供数据存储访问服务,如数据库、缓存、文件、搜索引擎等。

 

    • 分割
    • 分布式

常用方案:

  1. 分布式应用和服务
  2. 分布式静态资源
  3. 分布式数据和存储
  4. 分布式计算
    • 集群
    • 缓存
      1. CDN
      2. 反向代理
      3. 本地缓存
      4. 分布式缓存
    • 异步
      1. 提高系统可用性
      2. 加快网站响应速度
      3. 消除并发访问高峰
    • 冗余
    • 自动化
      1. 发布过程自动化
      2. 自动化代码管理
      3. 自动化测试
      4. 自动化安全检测
      5. 自动化部署
      6. 自动化监控
      7. 自动化报警
      8. 自动化失效转移
      9. 自动化失效恢复
      10. 自动化降级
      11. 自动化分配资源
    • 安全
    • 大型网站核心架构要素
      • 性能
      • 可用性:主要手段是冗余
      • 伸缩性:衡量标准是是否可以用多台服务器构建集群,是否容易向集群中添加新的服务器。
      • 扩展性
  1. 事件驱动架构:利用消息队列实现,将用户请求和其他业务事件构造成消息发布到消息队列,消息的处理者作为消费者从消息队列中获取消息进行处理。
  2. 分布式服务:将业务和可复用服务分离开来,通过分布式服务框架调用。
      • 安全性
  • 架构
  • 瞬时响应:网站高性能架构
  1. 网站性能测试
    • 不同视角下的网站性能:
  1. 用户视角的网站性能:
  1. 用户计算机和网站服务器通信的时间
  2. 网站服务器处理的时间
  3. 用户计算机浏览器构造请求解析响应应用数据的时间。
  1. 开发人员视角的网站性能:
  1. 相应延迟
  2. 系统吞吐量
  3. 并发处理能力
  4. 系统稳定性

 

优化手段:

  1. 使用缓存加速数据读取
  2. 使用集群提高吞吐量能力
  3. 使用异步消息加快请求响应及实现削峰
  4. 使用代码优化手段改善程序性能

 

  1. 运维人员视角的网站性能:
  1. 基础设施性能
  2. 资源利用率
    • 性能测试指标:
      1. 响应时间
      2. 并发数
      3. 吞吐量:TPS(每秒事务数)、HPS(每秒HTTP请求数)、QPS(每秒查询数)
      4. 性能计数器
    • 性能测试方法:
      1. 性能测试
      2. 负载测试
      3. 压力测试
      4. 稳定性测试
    • 性能优化策略:
      1. Web前端性能优化
      2. 应用服务器性能优化
      3. 存储服务器性能优化
  3. Web前端性能优化
    • 浏览器访问优化
      1. 减少http请求:主要手段是合并CSS、合并JavaScript、合并图片
      2. 使用浏览器缓存
      3. 启用压缩
      4. CSS放在页面最上面、JavaScript放在页面最下面
      5. 减少Cookie传输
    • CDN加速:(Content Distribute Network,内容分发网络)的本质仍然是一个缓存,而且将数据缓存在离用户最近的地方,使用户以最快速度获取数据,即所谓网络访问第一跳。
    • 反向代理;
      1. 具有保护网站安全的作用
      2. 通过配置缓存功能加速Web请求
      3. 可以实现负载均衡
  4. 应用服务器性能优化:主要手段有缓存、集群、异步
    • 分布式缓存
      1. 缓存的基本原理;
        1. 缓存主要用来存放那些读写比很高,很少变化的数据。
        2. 二八定律:80%的访问落在20%的数据上。
      2. 合理使用缓存
        1. 错误使用:
          1. 频繁修改的数据:读写比2:1以上,缓存才有意义
          2. 没有热点的访问
        2. 数据不一致与脏读:设置失效时间
        3. 缓存可用性
        4. 缓存预热:LRU(最近最久未用算法)
        5. 缓存穿透
      3. 分布式缓存架构:
        1. 需要更新同步的分布式缓存(JBoss Cache)
        2. 不互相通信的分布式缓存(Memcached)
    • 异步操作
      1. 使用消息队列具有很好的削峰作用
    • 使用集群
    • 代码优化;
      1. 多线程:
        1. 启动线程数=[任务执行时间/(任务执行时间- IO等待时间)] *CPU内核数
        2. 将对象设计为无状态对象
        3. 使用局部对象
        4. 并发访问资源时使用锁
      2. 资源复用
      3. 数据结构
      4. 垃圾回收
  5. 存储性能优化:
    • 机械硬盘、固态硬盘
    • B+树、LSM树:LSM树上进行一次数据更新不需要磁盘访问,在内存即可完成,速度远快于B+树。当数据访问以写操作为主,而读操作则集中在最近写入的数据上时,使用LSM树可以极大程度地减少磁盘的访问次数,加快访问速度。
    • RAID、HDFS
      1. RAID(廉价磁盘冗余阵列)技术主要是为了改善磁盘的访问延迟、增强磁盘可用性和容错能力。
        1. RAID0:数据在从内存缓冲区写入磁盘时,根据磁盘数量将数据分成N份,这些数据同时并发写入N块磁盘,使得数据整体写入速度是一块磁盘的N倍。
        2. RAID1:数据在写入磁盘,将一份数据同时写入两块磁盘,这样任何一块磁盘损坏都不会导致数据丢失,插入一块新磁盘就可以通过赋值数据的方式自动修复,具有极高的可靠性。
        3. RAID10:结合RAID0和RAID1两种方案,将所有磁盘平均分成两份,数据同时在两份磁盘写入,相当于RAID1,但是在每一份磁盘里的N/2块磁盘上,利用RAID0技术并发读写,既提高可靠性又改善性能,不过RAID10的磁盘利用率较低,有一半的磁盘用来写备份数据。
        4. RAID3:在数据写入磁盘的时候,将数据分成N-1份,并发写入N-1块磁盘,并在第N块磁盘记录校验数据,任何一块磁盘损坏(包括校验数据磁盘),都可以利用其他N-1块磁盘的数据修复。
        5. RAID5:与RAID3很相似,但是校验数据不是写入第N块磁盘,而是螺旋式地写入所有的磁盘中。
        6. RAID6:与RAID5类似,但是数据只写入N-2块磁盘,并螺旋式地在两块磁盘中写入校验信息(使用不同算法生成)。
      2. HDFS(hadoop分布式文件系统)

 

  • 万无一失:网站的高可用架构
    1. 网站可用性(Availability)描述网站可有效访问的特性。
      1. 网站可用性度量:

网站不可用时间(故障时间)=故障修复时间点-故障发现(报告)时间点

网站年度可用性指标=(1-网站不可用时间/年度总时间)*100%

      1. 网站可用性考核:

可用性指标是网站架构设计的重要指标,对外是服务承诺,对内是考核指标。

故障分=故障时间(分钟)*故障权重

    1. 高可用的网站架构
      1. 应用层:主要负责具体业务逻辑处理
      2. 服务层:负责提供可复用的服务
      3. 数据层:负责数据的存储和访问
    2. 高可用应用
      1. 通过负载均衡进行无状态服务的失效转移
      2. 应用服务器集群的Session管理
    3. 高可用的服务
      1. 分级管理
      2. 超时设置
      3. 异步调用
      4. 服务降级
      5. 幂等性设计
    4. 高可用的数据
      1. CAP原理:数据一致性(Consistency)、数据可用性(Availability)、分区耐受性(Partition Tolerance)
      2. 数据备份:异步热备份、同步热备份
      3. 失效转移:
  1. 失效确认:心跳检测、应用程序访问失败报告
  2. 访问转移
  3. 数据恢复
    1. 高可用网站的软件质量保证
      1. 网站发布
      2. 自动化测试
      3. 预发布验证:
  1. 预发布服务器是一种特殊用途的服务器,它和线上的正式服务器唯一的不同就是没有配置在负载均衡服务器上,外部用户无法访问。
  2. 预发布服务器和线上正式服务器都部署在相同的物理环境中,使用相同的线上配置,依赖相同的外部服务。
      1. 代码控制:
  1. 主干开发、分支发布
  2. 分支开发、主干发布
      1. 自动化发布
      2. 灰度发布(金丝雀发布)
    1. 网站运行监控:不允许没有监控的熊谈上线
      1. 监控数据采集:
  1. 用户行为日志收集;
    1. 服务端日志收集
    2. 客户端浏览器日志收集
  2. 服务器性能监控
  3. 运行数据报告
      1. 监控管理:
  1. 系统报警
  2. 失效转移
  3. 自动优雅降级
  • 永无止境:网站的伸缩性架构
    1. 网站架构的伸缩性设计
      1. 伸缩性是指不需要改变网站的软硬件设计,仅仅通过改变部署的服务器数量就可以扩大或者缩小网站的服务处理能力。
  1. 根据功能进行物理分离实现伸缩:不同服务器部署不通的服务,提供不同的功能
    1. 纵向分离(分层后分离):将业务处理流程上的不同部分分离部署,实现系统伸缩性。
    2. 纵向分离(业务分隔后分离):将不同的业务模块分离部署,实现系统伸缩性
  2. 单一功能通过集群实现伸缩:集群内的多台服务器部署相同的服务,提供相同的功能
    1. 应用服务器集群的伸缩性设计
  1. HTTP重定向负载均衡:HTTP重定向服务器是一台普通的应用服务器,其唯一的功能就是根据用户的HTTP请求计算一台真实的Web服务器地址,并将该Web服务器地址写入HTTP重定向响应中(响应状态码302)返回给用户浏览器。
  2. DNS域名解析负载均衡:每次域名解析请求都会根据负载均衡算法就算一个不同的IP地址返回。
  3. 反向代理负载均衡:利用反向代理服务器进行负载均衡
  4. IP负载均衡:在网络层通过修改请求目标地址进行负载均衡
  5. 数据链路层负载均衡:数据链路层负载均衡是指在通信协议的数据链路层修改mac地址进行负载均衡。
  6. 负载均衡算法:
    1. 轮询(Round Robin,RR)
    2. 加权轮询(Weighted Round Robin,WRR)
    3. 随机(Random)
    4. 最少连接(Least Connections)
    5. 源地址散列(Source Hashing)
    1. 分布式缓存集群的伸缩性设计
      1. 必须让新上线的缓存服务器对整个分布式缓存集群影响最小,也就是说新加入缓存服务器后应使整个缓存服务器集群中已经缓存的数据尽可能还被访问到,这就是分布式缓存集群伸缩性设计的最主要目标。
      2. 计算机的任何问题都可以通过增加一个虚拟层来解决。
    2. 数据存储服务器集群的伸缩性设计
      1. 关系数据库集群的伸缩性设计:读写分离、数据分库、Cobar(分布式关系数据库访问代理)
      2. NoSQL数据库的伸缩性设计:
  • 随需应变:网站的可扩展架构
    1. 概念:
      1. 扩展性(Extensibility):指对现有系统影响最小的情况下,系统功能可持续扩展或提升的能力。
      2. 伸缩性(Scalability):指系统能够通过增加(减少)自身资源规模的方式增强(减少)自己计算处理事务的能力。
    2. 构建可扩展的网站架构
      1. 度量一个开发框架、设计模式、编程语言优劣的中有尺度就是衡量它是不是让软件开发过程和软件产品跟家低耦合。
      2. 作者认为,软件架构师最大的价值不在于掌握多少先进的技术,而在于具有将一个大系统切分成N个低耦合的子模块的能力,这些子模块包含横向的业务模块,也包含纵向的基础技术模块。这种能力一部分源自专业的技术和经验,还有一部分源自架构师对业务场景的理解、对人性的把握、甚至对世界的认知。
    3. 利用分布式消息队列降低系统耦合性
      1. 事件驱动架构
      2. 分布式消息队列
    4. 利用分布式服务打造可复用的业务平台
      1. 巨无霸系统的问题:
  1. 编译、部署困难
  2. 代码分支管理困难
  3. 数据库连接耗尽
  4. 新增业务困难
      1. Web Service与企业级分布式服务
        • 缺点:
  1. 臃肿的注册与发现机制
  2. 低效的XML序列化手段
  3. 开销相对较高的HTTP的远程通信
  4. 复杂的部署与维护手段
      1. 大型网站分布式服务的需求与特点
          1. 负载均衡
          2. 失效转移
          3. 高效的远程通信
          4. 整合异构系统
          5. 对应用最小侵入
          6. 版本管理
          7. 实时监控
      2. 分布式服务框架设计
  1. SOA(Service Oriented Architecture 面向服务的体系架构)
    1. 可扩展的数据结构
    2. 利用开放品台建设网站生态圈
      1. API接口
      2. 协议转换
      3. 安全
      4. 审计
      5. 路由
  • 固若金汤:网站的安全架构
    1. 网站安全:
      1. XSS攻击(Cross Site Script 跨站点脚本攻击,指黑客通过篡改网页,注入恶意HTML脚本,在用户浏览网页时,控制用户浏览器进行恶意操作的一种攻击方式):
  1. 反射型:攻击者诱使用户点击一个嵌入恶意脚本的连接,达到攻击的目的。
  2. 持久型:黑客提交含有恶意脚本的请求,保存在被攻击的Web站点的数据库中,用户浏览网页时,恶意脚本被包含在正常页面中,达到攻击的目的。
      1. XSS防攻击手段:
  1. 消毒
  2. HttpOnly
      1. 注入攻击
  1. SQL注入攻击
  2. OS注入攻击
      1. 注入防攻击手段:
  1. 消毒
  2. 参数绑定
      1. CSRF攻击:
  1. CSRF(Cross Site Request Forgery,跨站点请求伪造),攻击者通过跨站请求,以合法的用户的身份进行非法操作。
  2. 防御手段:
    1. 表单Token
    2. 验证码
    3. Referer check
      1. 其他攻击和漏洞
  1. Error Code
  2. HTML注释
  3. 文件上传
  4. 路径遍历
      1. Web应用防火墙
      2. 网站安全漏洞扫描
    1. 信息加密技术及密匙安全管理
      1. 单向散列加密
      2. 对称加密
      3. 非对称加密
    2. 信息过滤与反垃圾
      1. 文本匹配:主要解决敏感词过滤的问题;可以通过正则表达式匹配、通过构造多级Hash表进行文本匹配。
      2. 分类算法:贝叶斯分类算法、朴素贝叶斯算法
      3. 黑名单
    3. 电子商务风险控制
      1. 风险
  1. 账户风险
  2. 卖家风险
  3. 卖家风险
  4. 交易风险
      1. 风控
  1. 机器将自动风控技术手段:
    1. 规则引擎:四一中将业务规则和规则处理逻辑相分离的技术
    2. 统计模型:
  • 案例
  • 淘宝网的架构演化案例分析
  • 维基百科的高性能架构设计分析
  • 海量分布式存储系统Doris的高可用架构设计分析
  • 网购秒杀系统架构设计案例分析
  • 大型网站典型故障案例分析
    1. 写日志也会引发故障
    2. 高并发访问数据库引发的故障
    3. 高并发情况下锁引发分故障
    4. 缓存引发的故障
    5. 应用启动不同步引发的故障
    6. 大文件读写独占磁盘引发的故障
    7. 滥用生产环境引发的故障
    8. 不规范的流程引发的故障
    9. 不好的编程习惯引发的故障
  • 架构师
  • 架构师领导艺术
    1. 架构师职能:
      1. 架构设计
      2. 软件开发技术工作
      3. 规划产品路线
      4. 估算人力资源和人力资源
      5. 安排人员职责分工
      6. 确定计划里程碑点
      7. 指导工程师工作
      8. 过程风险评估与控制
    2. 关注人而不是产品
      1. 一群优秀的人做一件他们热爱的事,一定能取得成功。
      2. 寻找一个值得共同奋斗的目标,营造一个让大家都能最大限度发挥自我价值的工作氛围。
    3. 发掘人的优秀
      1. 是事情成就人,而不是人成就了事。
      2. 发掘人的优秀远比发掘优秀的人更有意义。
    4. 共享美好蓝图
      1. 蓝图应该是表述清楚的
      2. 蓝图应该是形象的
      3. 蓝图应该是简单的
    5. 共同参与架构
      1. 不要只有架构师一个人拥有架构
      2. 让其他人维护框架与框架文档
    6. 学会妥协
      1. 对于技术细节的争论应该立即验证而不是继续讨论
    7. 成就他人
      1. 我们活着是为了成就我们自己,而要想成就自己,就必须首先成就他人。
      2. 在项目过程中不要试图去控制什么,带着一个弹性的计划和蓝图推进,团队会管好他们自己。
  • 网站架构师职场攻略
    1. 发现问题,寻找突破
    2. 提出问题,寻求支持
      1. 把“我的问题”表述成“我们的问题”
      2. 给上司提封闭式问题,给下属提开放式问题
      3. 指出问题而不是批评人
      4. 用赞同的方式提出问题
    3. 解决问题,达成绩效
  • 漫画网站架构师
    1. 按作用划分架构师:
      1. 设计型架构师
      2. 救火型架构师
      3. 布道型架构师
      4. Geek型架构师
    2. 按效果划分架构师
      1. 夏尔巴人架构师
      2. 斯巴达人架构师
      3. 达官贵人架构师
    3. 按职责角色划分架构师
      1. 产品架构师
      2. 基础服务架构师
      3. 基础设施架构师
    4. 按关注层次划分架构师
      1. 只关注功能的架构师
      2. 关注非功能的架构师
      3. 关注团队组织与管理的架构师
      4. 关注产品运营的架构师
      5. 关注产品未来的架构师
    5. 按口碑划分架构师
      1. 最好的架构师
      2. 好的架构师
      3. 一般的架构师
      4. 差的架构师
      5. 最差的架构师
    6. 非主流方式划分架构师
      1. 普通架构师
      2. 文艺架构师
      3. 1+1架构师

 

附录A 大型网站架构技术一览

  1. 前端架构
    • 浏览器优化技术
    • CDN
    • 动静分离、静态资源独立部署
    • 图片服务
    • 反向代理
    • DNS
  2. 应用层架构
    • 开发框架
    • 页面渲染
    • 负载均衡
    • Session管理
    • 动态页面静态化
    • 业务拆分
    • 虚拟化服务器
  3. 服务层架构
    • 分布式消息
    • 分布式服务
    • 分布式缓存
    • 分布式配置
  4. 存储层架构
    • 分布式文件
    • 关系数据库
    • NoSQL数据库
    • 数据同步
  5. 后台架构
    • 搜索引擎
    • 数据仓库
    • 推荐系统
  6. 数据采集与监控
    • 浏览器数据采集
    • 服务器业务数据采集
    • 服务器性能数据采集
    • 系统监控
    • 系统报警
  7. 安全建构
    • Web攻击
    • 数据保护
  8. 数据中心机房架构
    • 机房架构
    • 机柜架构
    • 服务器架构

 

附录B Web开发家属发展历程

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值