美文网首页
Web 性能优化方案

Web 性能优化方案

作者: 独钓寒江月 | 来源:发表于2019-08-26 12:55 被阅读0次

    首先要搞清楚用户访问网站时,经历了哪些步骤,我们才好从每一步中寻找可以优化的地方。

    步骤 及 优化方法

    1. 查看缓存
      当访问某个页面时,浏览器会先检查本地有没有缓存。

    方法:如果有缓存,就使用本地缓存的页面;如果没有缓存,在访问服务器。

    1. DNS 查询

    浏览器访问某网站的服务器,要先进行 DNS 查询。也就是,拿到地址栏中的地址,去 DNS 服务器查询相应的 数字IP 地址,然后使用 数字IP 地址去访问该网站的服务器。

    方法:减少 DNS 查询,即,尽量减少域名。

    举例来说,如果 a.css 放在 A 网站,b.css 放在 B 网站,那么就要进行两次 DNS 查询;我们可以把 a.css 和 b.css 放在同一个网站,这样就只要进行一次 DNS 查询。

    1. 建立 TCP 连接

    方法:TCP 连接连接复用。
    即,在 HTTP 协议中加上一个请求头 keep-alive,服务器就会保持连接,当第二次请求时,就复用之前的那个连接。
    另外,如果使用的是 HTTP/2.0 版本,连接复用率是更高的(多路复用)。

    1. 发送 HTTP 请求

    HTTP 请求有 4 部分:
    第一部分:请求行,不能优化。
    第二部分:请求头。方法1:不要滥用 Cookie;减少 Cookie 体积。
    第三部分:回车。
    第四部分:请求的内容。方法2:在请求头中设置 Cache-Control,让浏览器使用本地的缓存文件。
    方法3:合并CSS和JS文件,减少请求数。
    方法4:增加域名同时请求多个文件。
    同一域名可以同时请求多个 CSS 和 JS。但是不同的浏览器存在着差别:IE 浏览器最多只能同时请求 4 个文件,Chrome 浏览器最多可以同时请求 8 个文件。

    由于 IE 只能从同一域名同时请求 4 个文件,所以我们可以将文件放在不同域名,那么 IE 就可以从不同域名,同时请求超过 4 个文件,那么请求速度不就加快了吗。

    但是这与上面第 2 步冲突了。第 2 步提到,要减少域名,这里又说把文件放到不同的域名,那就要增加域名。

    那么这里,我们就要做个“权衡”,具体情况具体分析:

    如果文件多,可以放到不同域名,以此减少浏览器请求的时间(多域名);
    如果文件少,就可以放到一个域名,以此减少 DNS 查询时间(少域名)。

    1. 接收响应

    方法1:使用 ETag。
    ETag 可以做到,当服务器发现你请求的文件是最新的(通过MD5值比对),就不给你再发送文件,而是发送 304,让你使用上次发送过的文件。

    方法2:使用 Gzip。
    服务器将 html、css、js 等文件压缩,浏览器接收压缩后的文件。
    当然如果文件小,就不用 Gzip。
    因为浏览器在进行解压时,也会耗费时间。

    1. 接收完成,解析 HTML

    解析 HTML 的时候,有以下步骤:

    查看 DOCTYPE,根据 DOCTYPE 选择使用 html 或者 xml 等
    方法1:DOCTYPE 标签不能写错,也不能不写。
    因为这样会导致浏览器解析 HTML时间变才, 甚至解析出错。

    然后开始逐行解析
    方法2:不要写太多无用的标签。

    看到标签,浏览器会干嘛呢?Chrome 浏览器不会立即渲染该标签,它会等所有 CSS 加载完了,再渲染该标签。
    方法3:把 CSS文件 放到 head 标签,这样可以尽早渲染页面。

    1. 下载解析CSS 和 JS

    当浏览器碰到 CSS 和 JS 时,就会下载 CSS 或 JS,然后解析。
    下载是并行的,而解析是串行的。
    方法1:把 CSS文件 和 JS 文件放到 CDN(内容分发网络)。
    文件放到 CDN的好处:

    1. 增大同时下载的数量。
    2. 如果客户端与服务器距离较远,放到 CDN可以减少通信过程中的时间损耗。
    3. 访问CDN不需要Cookie,从而减少了Cookie体积。

    方法2:JS文件 放到 body 标签最后。
    这样可以尽早显示页面,因为解析 JS 会阻塞页面渲染,同时还可以让 JS 获取到所以DOM节点。

    其他优化方法
    延迟加载(懒加载)
    先下载第一屏内容,后面内容根据用户动作延迟加载。
    避免空 src 的图片,可以写成 <img src="about:blank"/>
    避免使用 @import 引入 CSS 文件。
    图片压缩

    好的无损压缩图片工具

    第一:Tinypng
    地址:https://tinypng.com/
    最大限度的做到对画质无损的进行压缩,支持对Jpg和Png的压缩。

    第二:Compressor.io
    地址:https://compressor.io/compress
    Compressor支持JPG,PNG,GIF,SVG多种格式的照片。

    第三:Kraken.io
    工具地址:https://kraken.io/web-interface
    Kraken可以把Zip中的文件一次性导入到工具中进行压缩,同时它支持不同的格式同时进行压缩。

    第四:Giftofspeed
    JPG压缩:https://www.giftofspeed.com/jpg-compressor/
    Png压缩:https://www.giftofspeed.com/png-compressor/
    在Giftofspeed,你可以输入你的网址,然后这个工具会建议你对图片进行优化,这样你就可以发现很多问题。

    第五: OptimiZilla
    地址:http://optimizilla.com/
    这个工具可以批量上传和批量压缩图片,一次可以上传20张图片;
    同时他的压缩程度大小可以有你自己来调节,而且是尽量的不改变画质。

    总结优化方法

    1. 减少 DNS 查询,即,尽量减少域名。
    2. TCP 连接连接复用。
    3. 不要滥用 Cookie;减少 Cookie 体积。
    4. 在请求头中设置 Cache-Control,让浏览器使用本地的缓存文件。
    5. 合并CSS和JS文件,减少请求数。
    6. 文件多时,增加域名同时请求多个文件。
    7. 使用 ETag。
    8. 使用 Gzip压缩文件。
    9. DOCTYPE 标签不能写错,也不能不写。
    10. 不要写无用的标签,减少标签数。
    11. 把 CSS文件 放到 head 标签,这样可以尽早渲染页面。
    12. JS文件 放到 body 标签最后。
    13. 把 CSS文件 和 JS 文件放到 CDN。
    14. 使用延迟加载(懒加载)。
    15. 避免空 src 的图片,可以写成 <img src="about:blank"/>。
    16. 避免使用 @import 引入 CSS 文件。
    17. 尽量压缩图片。

    最后

    怎么看某个网站有没有优化好呢?
    控制台 -> Audits -> Run audits 。

    相关文章

      网友评论

          本文标题:Web 性能优化方案

          本文链接:https://www.haomeiwen.com/subject/pokrectx.html