彻底掌握基于HTTP网络层的 “前端性能优化”

  • 产品性能优化方案

HTTP网络层优化
代码编译层优化 webpack
代码运行层优化 html/css javascript vue react
安全优化xss + csrf
数据埋点及性能监控

从输入URL地址到看到页面,中间都经历了啥

  • 第一步:URL解析
  • 地址解析
  • 编码:中文字符特殊字符等
  • 第二步:缓存检查
  • 缓存位置

    • Memory Cache 内存缓存
    • Disk Cache 硬盘缓存
  • 缓存检查机制
    • 打开网页:查找disk cache中是否有匹配,如果有则使用,没有则发送网络请求
    • 普通刷新(F5):因TAB页没有关闭,因此memory cache是可用的,会被优先使用,其次才是disk cache
    • 强制刷新(ctrl+F5):浏览器不使用缓存,因此发送的请求头部均带有Cache-control:no-cache,服务器直接返回200和最新内容
  • 缓存类型
    • 强缓存 Expires / Cache-Control

      • 浏览器对于强缓存处理:根据第一次请求资源时返回的响应头来确定
      • Expires:缓存过期时间,用来指定资源的到期时间(HTTP1.0)
      • Cache-Control:cache-control: max-age=2592000第一次拿到资源后的2592000秒内(30天),再次发送请求时会直接读取缓存中的信息(HTTP1.1)
      • 两者同时存在的话,Cache-Control的优先级高于Expires
    • 协商缓存Last-Modified / ETag
      • 协商缓存就是强制缓存失效后,浏览器携带缓存标识向服务器发起请求,由服务器根据缓存标识决定是否使用缓存的过程
      • 客户端第一次请求数据时,服务器会分配一个缓存标识给客户端,当客户端再次请求服务器时需要携带该缓存标识一起发送给服务器,服务器根据资源文件是否有更新来返回相应内容:如果没更新,返回304通知客户端读取缓存信息,如果有更新则返回200及最新资源信息,以及新的缓存标识Last-Modified / ETag
    • 数据缓存:数据缓存是手动设置的,在js中有个localStorage/sessionStorage可以用来保存数据到本地,当下次请求时可以直接从这里获取数据
  • 第三步:DNS解析
  • DNS解析就是浏览器在请求数据前,会先将域名信息发送给域名解析服务器,由域名解析服务器根据域名解析出该域名所对应的真实服务器的IP地址并返回给客户端,然后客户端再根据拿到的IP地址向真实的服务器发送请求
  • 每次DNS解析时间大约在20~120毫秒
  • DNS解析过程一般分为两种:迭代查询和递归查询
    • 递归查询: 在解析前会优先查看有没有缓存,如果有缓存则直接读取缓存数据,没有则再查看本地hosts文件,本地DNS解析缓存,如果都没有最后再到本地DNS服务器
    • 迭代查询:则是优先解析根域名然后是等级域名然后是权威域名
  • DNS解析优化
    • 减少DNS请求次数
    • DNS与解析(DNS Prefetch):浏览器渲染的同时进行域名解析
    • 分服务器部署
      • 资源合理利用
      • 抗压能力加强
      • 提高HTTP并发
<meta http-equiv="x-dns-prefetch-control" content="on">
<link rel="dns-prefetch" href="//static.360buyimg.com"/>
<link rel="dns-prefetch" href="//misc.360buyimg.com"/>
<link rel="dns-prefetch" href="//img10.360buyimg.com"/>
<link rel="dns-prefetch" href="//d.3.cn"/>
<link rel="dns-prefetch" href="//d.jd.com"/>
  • 第四步:TCP三次握手
  • seq序号,用来标识从TCP源端项目的端发送的字节流,发起方发送数据时对此进行标记
  • ack确认号,只有ACK标志位为1时,确认序号才有效,ack=seq+1
  • 标志位:
    • ACK:确认序号有效
    • RST:重置连接
    • SYN:发起一个新连接
    • FIN:释放一个连接

三次握手为什么不用两次或四次?

  • TCP作为一种可靠传输控制协议,其核心思想:既要保证数据可靠传输,又要提高传输效率
  • 如果是两次那么会导致服务器发送消息给客户端,客户端没有回应则服务器无法确定客户端是否有收到消息
  • 如果是四次则多了一次就没有必要了
  • 第五步:数据传输

HTTP 报文

  • 请求报文
  • 响应报文
  • 响应状态码
    • 200 OK返回成功
    • 202 Accepted :服务器已接受请求,但尚未处理(异步)
    • 204 No Content:服务器成功处理了请求,但不需要返回任何实体内容
    • 206 Partial Content:服务器已经成功处理了部分 GET 请求(断点续传 Range/If-Range/Content-Range/Content-Type:”multipart/byteranges”/Content-Length….)
    • 301 Moved Permanently
    • 302 Move Temporarily
    • 304 Not Modified
    • 305 Use Proxy
    • 400 Bad Request : 请求参数有误
    • 401 Unauthorized:权限(Authorization)
    • 404 Not Found
    • 405 Method Not Allowed
    • 408 Request Timeout
    • 500 Internal Server Error
    • 503 Service Unavailable
    • 505 HTTP Version Not Supported
  • 第六步:TCP四次挥手
  • 为什么连接的时候是三次握手,关闭的时候却是四次挥手?

    • 服务器端收到客户端的SYN连接请求报文后,可以直接发送SYN+ACK报文
    • 但关闭连接时,当服务器端收到FIN报文时,很可能并不会立即关闭链接,所以只能先回复一个ACK报文,告诉客户端:”你发的FIN报文我收到了”,只有等到服务器端所有的报文都发送完了,我才能发送FIN报文,因此不能一起发送,故需要四步握手。
  • 第七步:页面渲染
    web前端高级 - 浏览器底层渲染机制及性能优化

性能优化汇总

  • 利用缓存
    1、对于静态资源文件实现强缓存和协商缓存(扩展:文件有更新,要保证及时刷新)
    2、对于不经常更新的接口数据采用本地存储做数据缓存(cookie、localStorage、vuex、redux等)

  • DNS优化
    1、分服务器部署,增加HTTP并发性
    2、DNS预解析(DNS Prefetch)

  • TCP的三次握手和四次挥手
    1、Connection:keep-alive

  • 数据传输
    1、减少数据传输的大小

    • 内容或者数据压缩(webpack等)
    • 服务器端开启GZIP压缩(一般能压缩60%左右)
    • 大批量数据分批次请求(如:下拉刷新或分页,保证首次加载请求数据少)

    2、减少HTTP请求次数

    • 资源文件合并处理
    • 使用字体图标
    • 雪碧图(精灵图)CSS-Sprit
    • 图片BASE64
  • CDN服务(地域分布式)

  • 采用HTTP2.0

  • 网络优化是前端性能优化中的重点内容,因为大部分的消耗都是发生在网络层,尤其是第一次页面加载,如何减少等待时间很重要(减少白屏的效果和时间)

    • LOADING人性化体验
    • 骨架屏(客户端+服务器端)
    • 图片延迟加载

HTTP1.0 和HTTP1.1及HTTP2.0的区别

  • HTTP1.0 和 HTTP1.1的区别

    • 缓存处理:HTTP1.0中主要使用Last_Mdified、Expires来作为缓存判断的标准,HTTP1.1则引入了更多的缓存控制策略:ETag和Cache_control
    • 带宽优化及网络连接的使用:HTTP1.1支持断点续传,返回码是206(Partial Content)
    • 错误通知管理:在HTTP1.1中新增了24个错误状态码, 如409(Conflict)表示请求的资源与资源的当前状态发生冲突;410(Gone)表示服务器上的资源被永久性的删除
    • Host头处理:在HTTP1.0中认为每台服务器都绑定一个唯一的IP地址,因此请求消息中的URL并没有传递主机名(hostname)。但随着虚拟主机技术的发展,在一台物理服务器上可以存在多个虚拟主机(Multi-homed Web Servers),并且它们共享一个IP地址。HTTP1.1的请求消息和响应消息都支持Host头域,且请求信息中如果没有Host头域会报一个错误(400 Bad Request)
    • 长连接: HTTP1.1中默认开启Connection:keep-alive,一定程度上弥补了HTTP1.0每次请求都要创建连接的缺点
  • HTTP2.0和HTTP1.x相比的一些新特性
    • 新的二进制格式(Binary Format),HTTP1.x的解析是基于文本,基于文本协议的格式解析存在天然缺陷,文本的表现形式有多样性,要做的健壮性考虑的场景必然很多;二进制则不同,只认0和1的组合,基于这种考虑HTTP2.0的协议解析决定采用二进制格式,实现方便且健壮
    • header压缩:HTTP1.x的header带有大量信息,且每次都要重复发送,HTTP2.0使用encoder来减少需要传输的header的大小,通讯双方各自cache一份header field表,既避免了重复header的传输,又减小了需要传输的大小
    • 服务端推送:例如:在网页上有一个style.css的请求,在客户端收到style.css数据的同时,服务端会将style.js的文件也推送给客户端,当客户端再次尝试获取style.js时就可以直接从缓存中获取到,不再发送请求
    • 多路复用(MultiPlexing)
      • HTTP1.0 :每次请求响应,建立一个TCP连接,用完关闭
      • HTTP1.1 :采用长连接(Connection:keep-alive),若干个请求排队串行化单线程处理,后面的请求等待前面的请求返回才能获得执行机会,一旦有某请求超时,后面的请求只能被阻塞,也就是常说的线头阻塞
      • HTTP2.0:多路复用,多个请求同时在一个连接上并行执行,某个请求任务耗时严重,不会影响其他连接的正常执行

web前端高级JavaScript - 彻底掌握基于HTTP网络层的“前端性能优化”相关推荐

  1. Tair LDB基于Prefixkey的范围查找性能优化项目中期总结

    "Tair LDB基于Prefixkey的范围查找性能优化"这个项目刚好进行了一个月,这一个月主要是熟悉项目.掌握项目和提出设计方案的过程,下面从几个方面总结下个人在该项目上所做的 ...

  2. Tair LDB基于Prefixkey的范围查找性能优化项目测试及完成总结报告

    项目这周就截止了,这算是我第一个有导师指导的真正意义上的C++项目,项目基本完成,想要实现的功能也已经实现,并做了大量的性能测试.不过这对于业界来说,可能完成的还不够成熟,还有许多待改进的地方,还不能 ...

  3. web前端高级JavaScript - 前端web高级开发知识体系课程大纲

    堆栈内存和闭包作用域 9种数据类型区别及相互转换 词法解析和变量提升 堆(Heap)栈(stack)内存及垃圾回收机制 JS底层运行机制:EC/AO/VO/GO 作用域(Scope)和作用域链(Sco ...

  4. X-admin经典前端后台管理模板,基于layui的轻量级前端后台管理框架,简单,兼容性好,面向所有层次的前后端程序

    X-admin 简介 X-admin基于layui的轻量级前端后台管理框架,简单免费,兼容性好,面向所有层次的前后端程序.创立于2017年初,为了敏捷WEB应用开发和简化企业应用开发而诞生的.#X-a ...

  5. jsp给前端注入值失败_基于 qiankun 的微前端最佳实践(图文并茂) 应用间通信篇...

    引言 大家好~ 本文是基于 qiankun 的微前端最佳实践系列文章之 应用间通信篇,本文将分享在 qiankun 中如何进行应用间通信. 在开始介绍 qiankun 的应用通信之前,我们需要先了解微 ...

  6. 前端基于浏览器存储的AJAX性能优化

    受后端开发redis启发,基于浏览器sessionStorage存储的ajax性能优化. 一.需求 随着单页面和前后端分离的兴起,ajax已经成为大部分前后端数据交互的途径.虽然ajax是异步的,但是 ...

  7. 【深度学习】基于 Alluxio 数据缓存的性能优化

    作者 | 车漾(阿里云高级技术专家).顾荣(南京大学 副研究员) 导读:Alluxio 项目诞生于 UC Berkeley AMP 实验室,自开源以来经过 7 年的不断开发迭代,支撑大数据处理场景的数 ...

  8. web前端高级JavaScript - 一道题彻底理解函数中this指向和闭包作用域

    关于函数中this指向和闭包作用域的一道练习题 javascript 代码 var x = 3,obj = {x: 5}; obj.fn = (function(){this.x *= ++x;ret ...

  9. nuxt解决首屏加载慢问题_滴普大前端 | 滴普是如何实现首屏加载性能优化的?...

    决定优化方向 首先打开 Inspect - Network 查看请求情况,从图片可以看出,DOMContentLoaded 时间为 2.67s,Load 时间为 3.45s,资源交换为 2.4MB. ...

最新文章

  1. UI设计培训技术分享:配色秘籍
  2. springmvc相关配置和用法
  3. 量化指标公式源码_通达信指标公式源码线上阴线指标公式
  4. 以下不属于计算机安全术语,基础知识(D).doc
  5. LinQ学习之旅(1)
  6. 物维管理、楼控系统、安防系统、巡检管理、电子巡更、门禁管理、变配电、给排水、防盗报警、消防报警、电梯监视、智能楼宇、物业管理、报修管理、维保管理、工单管理、物料管理、审批、租赁管理、楼宇管理、房产管理
  7. 小米速度!雷军再祭 All in AIoT 大招!
  8. Java 员工信息管理系统
  9. Python办公自动化——8行代码实现文件去重
  10. 精通 C++ 是个毛意思
  11. 电脑中毒,文件夹都变成exe文件怎么办?
  12. 找个好人就嫁了吧 - 刘思伟
  13. 今天刚到货的小米平板2,就出现dnx fastboot mode一直卡死黑屏
  14. fir.im Weekly - Mobile developer 利器分享
  15. 代理模式与三种方式实现SpringAOP!
  16. 科普:Java 后端开发常用的 10 种第三方服务
  17. Windows Media Player 无法播放
  18. 编程php计算行李托运费_飞机行李箱怎么算托运费?
  19. DS串应用—最长重复子串
  20. PLC编程基本功:梯形图与控制线路

热门文章

  1. HTML表格标签的案例
  2. O2O分享6:O2O的社会化营销(下)
  3. linux下面系统要 pppoe拨号上网,Linux系统下PPPOE拨号共享上网方法是什么?
  4. c语言中finally的作用,请问Finally中文是什么意思……
  5. Java包(package)详解
  6. 单词数据库 mysql_英语单词数据库 mysql
  7. windows网络连接不显示身份验证标签页解决办法
  8. 苏州5G最新规划:2021年建成23000个5G基站,大力推进5G应用
  9. 教育培训机构数据化指标-成本和费用
  10. 丝杆_常用硬件的种类以及选用_day17