美文网首页FrontGreeks-高级前端前端性能优化程序员
前端性能优化-对HTTP传输进行压缩

前端性能优化-对HTTP传输进行压缩

作者: yitalalww | 来源:发表于2016-09-13 14:59 被阅读5339次

原创作品,请勿抄袭,翻版必究。转载请注明作者。

简介

资深的前端开发人员都知道,在web开发中,对js、css、图片、font等都要进行压缩,尽可能的减小文件的大小,减少前端下载的时间,从而提高网页响应的时间。特别是在移动端,这对用户的流量还有影响。不过本文中所提的压缩并不是指这情况,而是在js,css、图片、font等资源已经压缩了的基础上(当然,这一步非必要条件,压不压缩看你心情,资源文件的压缩跟http传输过程的压缩没关系),在http传输过程中的再次压缩。

HTTP1.1中的Accept-Encoding

在HTTP1.1开始,Web客户端可以通过Acceppt-Encoding头来标识对压缩的支持。客户端HTTP请求头声明浏览器支持的压缩方式,服务端配置启用压缩,压缩的文件类型,压缩方式。当客户端请求到达服务器,服务器响应时对请求资源进行压缩,返回给客户端浏览器,浏览器按照相应的方式进行解析。

先来看下天猫网站的案例。

天猫首页index.js的HTTP过程

在HTTP请求中,accept-encoding: gzip, deflate, sdch, br是指客户端浏览器(这里是我的chrome浏览器)支持的压缩方式。在HTTP响应中,content-encoding:gzip 是指服务端使用了gzip这种压缩方式。

在google的network中我们可以看到,index.js是5kb,这是传输过程中的大小。当我们把它的文件下载下来查看时发现他是9.62kb,压缩了44%。

不仅仅只是天猫,在国内大多数网站上都能看到使用这个方法来优化前端性能的身影。

压缩方式选择哪一种?

上面提到的压缩方式有这么多种,我们应该使用哪一个呢?事实上这点不用我们操心,选择gzip就可以了,参考Yahoo!工程师的说法,支持gzip的浏览器范围最广,使用gzip的压缩效果最佳。实际上经过我亲自考证,www.tmall.com、www.taobao.com、www.jd.com、www.suning.com、www.qq.com、www.baidu.com 这些大型网站都无一例外的使用了gzip这种压缩方式。

如何使用gzip进行压缩

怎么样才能使用HTTP的这个属性来压缩呢?这才是本文的重点。其实很简单,客户端不用任何配置,在服务端配置即可,服务器不同,配置方法也不尽相同。本文以tomcat为例,用我亲自测试的过程来展现。

(1)tomcat的配置

以我电脑tomcat安装目录为例,找到F:\software\apache-tomcat-7.0.54\conf文件夹下的server.xml

compress="on" 表示开启压缩。

compressionMinSize="2048"表示会对大于2KB的文件进行压缩。一般按照如此配置,可根据自己需求而定。

compressableMimeType是指将进行压缩的文件类型,对js,css,图片的压缩可以大大提升压缩效果。

tomcat的server.xml的配置按照上述进行配置,重启tomcat服务器。

(2)压缩前后对比,效果明显!

在我的demo中,有js,css,jpg图片,font,mp4等基本涵盖所有常用的资源类型。上面是未压缩前的情况,值得注意的是上面的status都是200,都是未缓存的情况。size一列显示了传输过程中的大小。页面整体响应时间大概在800ms左右。

接下来我们查看一下使用gzip压缩后的情况(特别值得注意的是,修改了server.xml后重启tomcat是无效的。需要在eclipse中删除,然后在新创建一个tomcat服务器,需要指向我们刚刚配置的tomcat)。

上图是使用gzip压缩后的情况,非常明显的可以看出,document从原来的8.5KB压缩到现在的1.5KB,压缩了82%,angular.js压缩了75%,yitalaUI压缩了61.5%,jpg的图片几乎没有怎么压缩,微乎其微,可见我们上面的配置需要修改,只需要对document,js,css压缩即可。我们没有对font文件和mp4文件进行压缩,所以上面大小不变。

另外特别值得注意的是整体响应时间减少了200ms,提高了25%?真的是这样吗?错了,因为传输过程的时间跟网络有关系,我在本地电脑测试,网络是极好的,上面实际上是看不出传输时间的改善。减少了200ms是其他不确定的因素起的作用。实际上如果网站的document的大小和css,js文件数量越多则效果越明显。如果有条件,你可以自行搭建环境测试。

gzip的浏览器兼容性

在8年前,即2008年,yahoo团队的《High.Performance.Web.Sites》一书中就指出大部分浏览器都支持gzip。现在浏览器都已更新换代好几代了,基本上都支持gzip。因此我们不需要考虑客户端不支持的情况(不支持的情况是非常严重的)。

下面是浏览器对gzip的支持情况:

Netscape 6+ (Netscape 4-5 does, but with some bugs).

Internet Explorer 5.5+ (July 2000) and IE 4 if set to HTTP/1.1.

Opera 5+ (June 2000)

Lynx 2.6+ (some time before 1999)

Firefox 0.9.5+ (October 2001)

Chrome since forever

Safari since forever (as far as I can tell)

弊端

对HTTP传输内容进行压缩是改良前端响应性能的可用方法之一,大型网站都在用。但是也有缺点,就是压缩过程占用cpu的资源,客户端浏览器解析也占据了一部分时间。但是随着硬件性能不断的提高,这些问题正在不断的弱化。

本文中提到的方法,读者可大胆的使用。国内国外大型的网站都在使用,前端的性能优化必须对这些细节非常注意,变量引起质变,如果每个地方你都极尽最佳性能,你开发出来的网站性能将会尤其突出。

我会不断的推出前端性能优化的各种方法(每周一至二篇文章),站在巨人的肩膀上,加上我个人的亲自测试和研究,用图文并茂的方式向大家介绍。请大家关注我。

第一篇,前端性能重要性

第二篇,前端性能优化-HTTP添加Expires头

第三篇,前端新能优化-对HTTP传输进行压缩

第四篇,前端性能优化-将CSS文件放在顶部

第五篇,前端性能优化-将Scripts放在底部

相关文章

  • 前端性能优化-对HTTP传输进行压缩

    原创作品,请勿抄袭,翻版必究。转载请注明作者。 简介 资深的前端开发人员都知道,在web开发中,对js、css、图...

  • vue性能优化详解(二)

    前端路漫漫,优化无极限。本文主要从Webpack角度讲述vue性能优化。 1.Webpack 对图片进行压缩 如果...

  • 性能优化

    常见的性能优化方法: 对资源进行压缩1.压缩图片:雪碧图2.压缩html/css/js文件和后端文件:前端工程化工...

  • 前端性能优化(上)

    性能优化调研系列文章 《前端性能优化(上)》 《前端性能优化(中)》 《前端性能优化(下)》 为什么要进行前端性能...

  • 前端性能优化方式

    2.前端性能优化方式 减少http请求。 大量图片渲染使用懒加载技术,图片压缩。 压缩代码,将javascript...

  • js基础常见问题总结(三)~

    web前端性能优化总结 浏览器访问优化 1、减少http请求,合理设置 HTTP缓存2、使用浏览器缓存3、启用压缩...

  • 知识点整理(三)

    1. 前端性能优化的方法? (1) 减少http请求次数:CSS Sprites, JS、CSS源码压缩、图片大小...

  • 前端的性能优化

    你有用过哪些前端性能优化的方法?(1) 减少http请求次数:CSS Sprites, JS、CSS源码压缩、图片...

  • 关于前端性能优化问题详解

    关于前端性能优化问题详解 出处:http://segmentfault.com/blogs 前端性能优化指南 AJ...

  • 基于 Node.js 搭建 HTTP/2服务

    上文已经提到了HTTP/2主要利用多路复用传输,头部压缩,服务端推送,可以减少网络延迟对性能带来的影响,优化首次访...

网友评论

  • 934c71b90eb4:关于优化,
    还有一种是从源头上控制,
    比如图片,从源头上控制图片大小
    在前端对图片进行压缩,
    效果也挺好的
    关于前端图片压缩上传demo地址
    http://www.imwinlion.com/archives/1
    第一篇博文
    开张大吉
    前端js 实现后端go语言
  • 桥上风景:哇塞!你写的真好!一看就知道你是大学生吧?计算机系的英语还那么好。虽然我啥也看不懂。(我看不懂,你得原谅我。不是你写的没有技术含量,而是技术含量太高了!我初中生啊,你忘啦?)😜
    yitalalww:@桥上风景 傻逼,滚
  • c02585b16f8a:好好好

本文标题:前端性能优化-对HTTP传输进行压缩

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