给Tomcat,Apache配置gzip压缩(HTTP压缩)功能

HTTP 压缩可以大大提高浏览网站的速度。相对于普通的浏览过程HTML ,CSS,Javascript , Text ,它可以节省40%左右的流量。更为重要的是,它可以对动态生成的,包括CGIPHP , JSP , ASP , Servlet,SHTML等输出的网页也能进行压缩,压缩效率惊人

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

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

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

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

我这里的配置内容为:

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


二,对于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中添加

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


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

1clip_image001加载deflate模块
2clip_image001LoadModule headers_module modules/mod_headers.so
3clip_image001LoadModule deflate_module modules/mod_deflate.so
4clip_image001<VirtualHost *:80>
5clip_image001    DocumentRoot f:/apacheTest
6clip_image001    <Location "/">
7clip_image001        SetOutputFilter DEFLATE
8clip_image001        BrowserMatch ^Mozilla/4 gzip-only-text/html
9clip_image001        BrowserMatch ^Mozilla/4\.0[678] no-gzip
10clip_image001        BrowserMatch \bMSIE !no-gzip !gzip-only-text/html
11clip_image001        SetEnvIfNoCase Request_URI \.(?:gif|jpe?g|png)$ no-gzip dont-vary
12clip_image001        Header append Vary User-Agent env=!dont-vary
13clip_image001    </Location>
14clip_image001</VirtualHost>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值