zoukankan      html  css  js  c++  java
  • 设置TOMCAT启用GZIP压缩

    原理简介

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

    配置方法

    Tomcat5.0以后的版本是支持对输出内容进行压缩的,使用的是gzip压缩格式 。
     
    修改%TOMCAT_HOME%/conf/server.xml,修订节点如下:
    [xhtml] view plaincopy
     
    1. <Connector port="80" protocol="HTTP/1.1"   
    2.            connectionTimeout="20000"   
    3.            redirectPort="8443" executor="tomcatThreadPool" URIEncoding="utf-8"   
    4.                        compression="on"   
    5.                        compressionMinSize="50" noCompressionUserAgents="gozilla, traviata"   
    6.                        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" 哪些资源类型需要压缩
     

    对于某些文本文件比如:log、txt等文件,我们也可以让服务器采用gzip压缩传输,修改conf目录下web.xml,添加   

    <mime-mapping>
             <extension>log</extension>
             <mime-type>text/plain</mime-type>
    </mime-mapping>

    等,就可以指定压缩传输了。通常情况下,压缩传输能大幅度提高展示速度。

    Nginx和Tomcat同时启用GZIP的后果:

    http://www.iteye.com/topic/1118087

    新部署的一台服务器在做了性能调优以后发现FCK在线编辑器IE、firefox都出现报错,只有chrome正常。百思不得其解,差点就把FCK换掉。经过千辛万苦终于找到了原因(本人找错误原因的运气一直都非常好):

    开始以为是脚本乱码,看了文件头的那段注释以后确认不是这个问题。

    在firefox的firedebug上面看到的脚本一直报找不到对象的错误,难道是公司的网络龟速导致脚本加载顺序不协调所致?几次刷新以后问题还在,304状态码说明不是网络龟速的原因。

    最后把FCK的javascript脚本下载到本地以后一看,只有20k左右,而完整的是249K,看来我找到原因了~~

    还是百思不得其解,好好的静态脚本文件为什么会下载了一部分就完了呢?而且首次下载的状态码是200,之后的刷新都是304,这违反了我对HTTP状态码的理解。

    撇开前端的Nginx,直接访问tomcat居然页面就正常了。so~问题在nginx。nginx处理静态资源的能力从来都没有怀疑过(这再次违反了我对XXX的理解)。

    灵光一闪,前后端的服务器最近都进行了调优,难道是这次修改了 配置文件导致的?so首先关闭nginx的gzip  off;,重启Nginx后全世界正常了。随后关闭后端tomcat的compression="off",重新启用Nginx的gzip,问题终于解 决了。

    总结:多层服务器结构的系统启用gzip压缩要注意一个问题:前端服务器启用了gzip以后,后端的服务器就不要启用gzip压缩了,不然部分浏览器会下载到不完整的文件。

    测试方法

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

    通过浏览器直接请求

           大家直接通过浏览器访问启用了压缩配置的服务器,然后通过抓包工具查看抓到的数据包,如果内容有很多你看不懂,就说明已经启用压缩功能了。

    通过程序模拟请求

    我们用httpclient写一个简单的测试程序,代码如下:
    [java] view plaincopy
     
    1. @Test  
    2. public void testGzip() {  
    3.         HttpClient httpClient = new HttpClient();  
    4.         GetMethod getMethod = new GetMethod("http://localhost/admin.jsp");  
    5.         try {  
    6.                 getMethod.addRequestHeader("accept-encoding", "gzip,deflate");  
    7.                 getMethod.addRequestHeader("user-agent","Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0; Alexa Toolbar; Maxthon 2.0)");  
    8.                 int result = httpClient.executeMethod(getMethod);  
    9.                 if (result == 200) {  
    10.                         System.out.println(getMethod.getResponseContentLength());  
    11.                         String html = getMethod.getResponseBodyAsString();  
    12.                         System.out.println(html);  
    13.                         System.out.println(html.getBytes().length);  
    14.                 }  
    15.         } catch (HttpException e) {  
    16.                 e.printStackTrace();  
    17.         } catch (IOException e) {  
    18.                 e.printStackTrace();  
    19.         } finally {  
    20.                 getMethod.releaseConnection();  
    21.         }  
    22. }  

      执行这个junit程序,看看它所输出的是什么内容,如果输出的是一些乱码,并且打印内容的长度远小于实际的长度,就说明我们的配置生效了,通过一些其它验证工具,会发现网站浏览速度会明显提升。
     
    备注:如果发现内容没有被压缩,可以考虑调整compressionMinSize大小,如果请求资源小于这个数值,则不会启用压缩。
  • 相关阅读:
    SQL Server中事务transaction如果没写在try catch中,就算中间语句报错还是会提交
    EF Core中Key属性相同的实体只能被跟踪(track)一次
    Android--数据持久化之内部存储、Sdcard存储
    SQLite的介绍 操作Sqlite 具体实例
    Android提供了5种方式存储数据:
    Eclipse集成Tomcat的配置步骤实例
    如何实现上下左右键盘控制焦点使之落在相邻文本框或下拉框中-Web开发/JavaScript
    android布局
    android布局 及 布局属性
    Android开发之SD卡上文件操作
  • 原文地址:https://www.cnblogs.com/sanhuan/p/4828401.html
Copyright © 2011-2022 走看看