原理简介
HTTP压缩可以大大提高浏览网站的速度,它的原理是,在客户端请求服务器对应资源后,从服务器端将资源文件压缩,再输出到客户端,由客户端的浏览器负责解压缩并浏览。相对于普通的浏览过程HTML ,CSS,Javascript , Text ,它可以节省40%左右的流量。更为重要的是,它可以对动态生成的,包括CGI、PHP , JSP, ASP , Servlet,SHTML等输出的网页也能进行压缩,压缩效率也很高。双方的协商过程如下:
- 首先浏览器请求某个URL 地址,并在请求的头 (head) 中设置属性 accept-encoding 值为gzip,
deflate,表明浏览器支持 gzip 和 deflate 这两种压缩方式(事实上 deflate 也是使用 gzip 压缩协议); - WEB 服务器接收到请求后判断浏览器是否支持压缩,如果支持就传送压缩后的响应内容,否则传送不经过压缩的内容;
浏览器获取响应内容后,判断内容是否被压缩,如果是则解压缩,然后显示响应页面的内容。
备注:所以若启用tomcat 的Gzip 压缩网页数据,只需修改tomcat中的配置,客户端及服务端均不用再做其它改动。
配置方法
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" />
- compression=”on” 打开压缩功能
- compressionMinSize=”50” 启用压缩的输出内容大小,默认为2KB
- noCompressionUserAgents=”gozilla, traviata” 对于以下的浏览器,不启用压缩
compressableMimeType=”text/html,text/xml,text/javascript,text/css,text/plain” 哪些资源类型需要压缩
备注:如果发现内容没有被压缩,可以考虑调整compressionMinSize大小,如果请求资源小于这个数值,则不会启用压缩。
Gzip压缩图片
通过测试4种常见文件的gzip压缩效果,得出结论是bmp图片需要启用gzip压缩,其效果非常明显,压缩率可高达98%以上,而jpg、png和gif图片则无需启用gzip压缩,这3种图片不但压缩效果不明显,还可能导致压缩后体积变得更大而拖慢网速。