`
baalwolf
  • 浏览: 344563 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

给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

 

现在来说一下如何在TOM猫中一步到位(要求TOM猫5.0以后版本)。

在conf/server.xml中找到第一个Connector,加入如下属性即可,就是这么简单:

compression="on"
compressionMinSize="2048"
noCompressionUserAgents="gozilla, traviata"
compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain"

第一行表示开启gzip压缩,第二行表示启用压缩的输出内容大小,默认是2K,第三行表示需要排除的浏览器,第四行就是需要压缩的文件的mine类型了。

悄悄透露,使用之后,腰不酸了,腿不疼了,一口气上五楼。

最后,推荐两个GZIP在线检测的网站:

老外的:http://www.seoconsultants.com/tools/compression

国产的:http://gzip.iamzz.com/

 

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

分享到:
评论

相关推荐

    如何验证Tomcat Gzip配置是否生效的方法

    我们在使用Tomcat优化配置时,都会开始Tomcat的Gzip压缩功能,配置如下: &lt;Connector port=9080 protocol=HTTP/1.1 connectionTimeout=20000 redirectPort=8443 URIEncoding=UTF-8 useBodyEncodingForURI=...

    关于JavaScript的gzip静态压缩方法

    一个页面减少10KB对于一个小网站来说,算不上什么,但对于大型站点来说,累计起来却是一个很大的流量……gzip压缩是一个有效可行的方法,但需要Apache的支持(Apache与IIS共用一个端口解决方法)。 传统的JS压缩(删除...

    Nginx+Tomcat负载均衡

    Tomcat各种版本的下载地址我也提供给大家:http://tomcat.apache.org/download-60.cgi 大家可以先用我tomcat6 学会了,在下载自己需要的版本。 词条科普 另外我把实现过程中遇到的知识点都总结好了,一起提供给...

    实战Nginx:取代Apache的高性能Web服务器 第一章

    5.1 Nginx与JSP(Tomcat)在Linux上的安装、配置 5.2 Nginx与ASP.NET(Mono+FastCGI)在Linux上的安装、配置 5.3 Nginx与Perl(FastCGI)在Linux上的安装、配置 第6章 Nginx HTTP负载均衡和反向代理的配置与优化 6.1...

    实战Nginx.取代Apache的高性能Web服务器

    5.1 Nginx与JSP(Tomcat)在Linux上的安装、配置 5.2 Nginx与ASP.NET(Mono+FastCGI)在Linux上的安装、配置 5.3 Nginx与Perl(FastCGI)在Linux上的安装、配置 第6章 Nginx HTTP负载均衡和反向代理的配置与优化 ...

    ASP.NET Core中的响应压缩的实现

    我们熟悉的Web服务器,比如IIS、Tomcat、Nginx、Apache等都可以使用压缩技术,常用的压缩类型包括Brotli、Gzip、Deflate,它们对CSS、JavaScript、HTML、XML 和 JSON等类型的效果还是比较明显的,但是也存在一定的...

    实战nginx-张宴

    5.1 Nginx与JSP( Tomcat) 在Linux上的安装、 配置 5.2 Nginx与ASP.NET( Mono+FastCGI) 在Linux上的安装、 配置 5.3 Nginx与Perl( FastCGI) 在Linux上的安装、 配置 第6章 Nginx HTTP负载均衡和反向代理的配置...

    JAVA上百实例源码以及开源项目源代码

     Java数据压缩与传输实例,可以学习一下实例化套按字、得到文件输入流、压缩输入流、文件输出流、实例化缓冲区、写入数据到文件、关闭输入流、关闭套接字关闭输出流、输出错误信息等Java编程小技巧。 Java数组倒置...

    JAVA上百实例源码以及开源项目

     Java数据压缩与传输实例,可以学习一下实例化套按字、得到文件输入流、压缩输入流、文件输出流、实例化缓冲区、写入数据到文件、关闭输入流、关闭套接字关闭输出流、输出错误信息等Java编程小技巧。 Java数组倒置...

Global site tag (gtag.js) - Google Analytics