给Tomcat,Apache配置gzip压缩功能

<script type="text/JavaScript"> </script> <script src="http://a.alimama.cn/inf.js" type="text/javascript"></script>

 

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

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

下面是tomcat5.5.20 中的$tomcat_home$/conf/server.xml的原内容

1        < Connector port ="80" maxHttpHeaderSize ="8192"
2                  maxThreads ="150" minSpareThreads ="25" maxSpareThreads ="75"
3                  enableLookups ="false" redirectPort ="8443" acceptCount ="100"
4                  connectionTimeout ="20000" disableUploadTimeout ="true" URIEncoding ="utf-8" />
5       <!-- Note : To disable connection timeouts, set connectionTimeout value
6        to 0 -->
7      
8       <!-- Note : To use gzip compression you could set the following properties :
9      
10                  compression="on"
11                  compressionMinSize="2048"
12                  noCompressionUserAgents="gozilla, traviata"
13                  compressableMimeType="text/html,text/xml"
14       -->

从上面的第8行内容可以看出,要使用gzip压缩功能,你可以在Connector实例中加上如下属性即可
1) compression="on" 打开压缩功能
2) compressionMinSize="2048" 启用压缩的输出内容大小,这里面默认为2KB
3) noCompressionUserAgents="gozilla, traviata" 对于以下的浏览器,不启用压缩
4) compressableMimeType="text/html,text/xml" 压缩类型

我这里的配置内容为:

1      < Connector port ="80" maxHttpHeaderSize ="8192"
2                 maxThreads ="150" minSpareThreads ="25" maxSpareThreads ="75"
3                 enableLookups ="false" redirectPort ="8443" acceptCount ="100"
4                 connectionTimeout ="20000" disableUploadTimeout ="true" URIEncoding ="utf-8"
5                    compression ="on"
6                 compressionMinSize ="2048"
7                 noCompressionUserAgents ="gozilla, traviata"
8                 compressableMimeType ="text/html,text/xml,text/javascript,text/css,text/plain"    />
9      <!-- Note : To disable connection timeouts, set connectionTimeout value
10       to 0 -->
11     
12      <!-- Note : To use gzip compression you could set the following properties :
13     
14                 compression="on"
15                 compressionMinSize="2048"
16                 noCompressionUserAgents="gozilla, traviata"
17                 compressableMimeType="text/html,text/xml"
18      -->
19

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

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

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

 


二,对于Apache而言,有两种情况
   
1)针对Apache2.0之前的版本,它原本是不支持的,不过可以通过添加第三方的module_gzip模块来启用
    2)针对Apache2.0及之后的版本,Apache提供支持, 不过不叫gzip,而叫mod_deflate
下面就对Apache2.0及之后的版本作一个说明
1) 去掉#LoadModule headers_module modules/mod_headers.so前面的注释#,
2) 添加LoadModule deflate_module modules/mod_deflate.so
3) 在VirtualHost中添加

1      < Location "/" >
2          SetOutputFilter DEFLATE
3          BrowserMatch ^Mozilla/4 gzip-only-text/html
4          BrowserMatch ^Mozilla/4/.0[678] no-gzip
5          BrowserMatch /bMSIE !no-gzip !gzip-only-text/html
6          SetEnvIfNoCase Request_URI /.(?:gif|jpe?g|png)$ no-gzip dont-vary
7          Header append Vary User-Agent env=!dont-vary
8      </ Location >
9


我这里面有一个完整的演示

1   # 加载deflate模块
2   LoadModule headers_module modules/mod_headers.so
3   LoadModule deflate_module modules/mod_deflate.so
4   < VirtualHost *:80 >
5      DocumentRoot f:/apacheTest
6      < Location "/" >
7          SetOutputFilter DEFLATE
8          BrowserMatch ^Mozilla/4 gzip-only-text/html
9          BrowserMatch ^Mozilla/4/.0[678] no-gzip
10          BrowserMatch /bMSIE !no-gzip !gzip-only-text/html
11          SetEnvIfNoCase Request_URI /.(?:gif|jpe?g|png)$ no-gzip dont-vary
12          Header append Vary User-Agent env=!dont-vary
13      </ Location >
14   </ VirtualHost >
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值