1. 首页
  2. 博客
  3. 详情

设置TOMCAT启用GZIP压缩

LovePanda  • 

原理简介

        HTTP 压缩可以大大提高浏览网站的速度,它的原理是,在客户端请求服务器对应资源后,从服务器端将资源文件压缩,再输出到客户端,由客户端的浏览器负责解压缩并浏览。相对于普通的浏览过程HTML ,CSS,Javascript , Text ,它可以节省40%左右的流量。更为重要的是,它可以对动态生成的,包括CGI、PHP , JSP , ASP , Servlet,SHTML等输出的网页也能进行压缩,压缩效率也很高。 

配置方法

Tomcat5.0以后的版本是支持对输出内容进行压缩的,使用的是gzip压缩格式 。
 

修改%TOMCAT_HOME%/conf/server.xml,修订节点如下:


    <Connector port="80" protocol="HTTP/1.1" 
               connectionTimeout="20000" 
               redirectPort="8443" executor="tomcatThreadPool" URIEncoding="utf-8" 
               compression="on" 
               compressionMinSize="50" noCompressionUserAgents="gozilla, traviata" 
       compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain" />


从上面节点的属性可以看出,要使用gzip压缩功能,你需要在Connector节点中加上如下属性
  • compression="on" 打开压缩功能 
  • compressionMinSize="50" 启用压缩的输出内容大小,默认为2KB 
  • noCompressionUserAgents="gozilla, traviata" 对于以下的浏览器,不启用压缩 
  • compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain" 哪些资源类型需要压缩

测试方法

启用了TOMCAT这个压缩功能后,我们如何来测试压缩是否有效呢?
首先Tomcat是根据浏览器请求头中的accept-encoding来判断浏览器是否支持压缩功能,如果这个值包含有gzip,就表明浏览器支持gzip压缩内容的浏览,我们可以用两种方法来验证压缩是否生效。

通过浏览器直接请求

       大家直接通过浏览器访问启用了压缩配置的服务器,然后通过抓包工具查看抓到的数据包,或者通过比如chrome浏览器的开发者工具查看network项。

上图是我的首页的检测结果,和之前比起来明显要小很多,浏览器速度也更快。

可以看到这个amazeui.js由432.72K压缩到100K了,所以效果是明显的。


使用GZIP测试网站测试


站长工具有一个gzip检测工具,网址为:http://tool.chinaz.com/Gzips/

我的首页检测结果为:

如果用到tomcat作为服务器容器的话不妨试试看。




声明:若要转载LovePanda中的任何博客请注明转载地址

分享到
LovePanda登录 ×
LovePanda注册 ×