`
624034748
  • 浏览: 3992 次
社区版块
存档分类
最新评论

Apache2.0 开启gzip压缩和浏览器缓存功能

阅读更多

 

先谈gzip的配置方法。

在apache2.0以上(包括apache2.0)的版中gzip压缩使用的是mod_deflate模块,下面是具体配置步骤:

第1步

 

  •     #LoadModule deflate_module modules/mod_deflate.so
  •     #LoadModule headers_module modules/mod_headers.so

 

打开 httpd.conf 后,先将上面两行配置前面的 # 号去掉,

这样apache就会启用这两个模块,其中

mod_deflate 是压缩模块,就是对要传输到客户端的代码进行gzip压缩;

mod_headers 模块的作用是告诉浏览器页面使用了gzip压缩,如果不开启mod_headers那么浏览器就会对gzip压缩过的页面进行下载,而无法正常显示。

第2步

在httpd.conf中加入以下代码,可以加到任何空白地方,不了解apache的朋友,如果担心加错地方,就放到http.conf文件的最后一行。

<IfModule mod_deflate.c>
      SetOutputFilter DEFLATE    #必须的,就像一个开关一样,告诉apache对传输到浏览器的内容进行压缩
    SetEnvIfNoCase Request_URI .(?:gif|jpe?g|png)$ no-gzip dont-vary #设置不对后缀gif,jpg,jpeg,png的图片文件进行压缩
    SetEnvIfNoCase Request_URI .(?:exe|t?gz|zip|bz2|sit|rar)$ no-gzip dont-vary #同上,就是设置不对exe,tgz,gz。。。的文件进行压缩
    SetEnvIfNoCase Request_URI .(?:pdf|mov|avi|mp3|mp4|rm)$ no-gzip dont-vary
       AddOutputFilterByType DEFLATE text/* #设置对文件是文本的内容进行压缩,例如text/html  text/css  text/plain等
    AddOutputFilterByType DEFLATE application/ms* application/vnd* application/postscript application/javascript application/x-javascript #这段代码你只需要了解application/javascript application/x-javascript这段就可以了,这段的意思是对javascript文件进行压缩
    AddOutputFilterByType DEFLATE application/x-httpd-php application/x-httpd-fastphp #这段是告诉apache对php类型的文件进行压缩
    BrowserMatch ^Mozilla/4 gzip-only-text/html # Netscape 4.x 有一些问题,所以只压缩文件类型是text/html的
    BrowserMatch ^Mozilla/4.0[678] no-gzip # Netscape 4.06-4.08 有更多的问题,所以不开启压缩
    BrowserMatch bMSIE !no-gzip !gzip-only-text/html # IE浏览器会伪装成 Netscape ,但是事实上它没有问题
    Header append Vary User-Agent env=!dont-vary #确保代理不会发送错误的内容
</IfModule>

 

具体配置内容可参考mod_deflate模块手册

 

本配置到这里apache中的gzip压缩就配置完成,重启apache后,新的配置就会生效,当然这里我们还不会重启apache因为下一步要配置http缓存,也就是mod_expires模块。

第1步

      #LoadModule expires_module modules/mod_expires.so

httpd.conf中,找到上面的代码,然后将前面的#去掉

第2步

在httpd.conf中加入以下代码,可以加到任何空白地方,不了解apache的朋友,如果担心加错地方,就放到http.conf文件的最后一行。

<IfModule mod_expires.c>
      ExpiresActive On #激活http缓存,也就是个开关,必须有的一段代码
    ExpiresDefault A604800 #默认缓存时间为604800秒,也就是7天,A表示以客户端时间为准
    ExpiresByType text/css A3600 #对css文件缓存3600秒,也就是1小时,A表示以客户端时间为准
    ExpiresByType text/html A3600 #对html文件缓存3600秒,也就是1小时,A表示以客户端时间为准
    ExpiresByType application/x-javascript A3600 #对javascript文件缓存3600秒,也就是1小时,A表示以客户端时间为准
    ExpiresByType image/* access plus 2 month #对图片类型缓存2个月,以客户端时间为准
    ExpiresByType image/x-icon access plus 2 month #对浏览器小图标缓存2个月,以客户端时间为准
    ExpiresByType application/x-shockwave-flash A2592000 #对flash文件缓存2592000秒,也就是1个月,A表示以客户端时间为准
        #特别注意也可以使用 ExpiresByType text/css M3600  这里的M表示以文件最后修改时间为准缓存1小时,例如有些时候,我们的HTML是大批量定时更新的,这个时候就可以用到M
      Header unset Pragma #删除掉http头信息中的Pragma,不懂的可以google一下Pragma,他也是控制浏览器缓存的,不过是用于http1.0标准FileETag None
      Header unset ETag #这段代码和上面一段的作用是不使用http1.1标准中的ETag属性
   <FilesMatch .(js|css|ico|pdf|flv|jpg|jpeg|png|gif|mp3|mp4|swf)$> #针对js|css|ico等后缀的文件进行单独设置
        #Header set Expires Thu, 15 Apr 2013 20:00:00 GMT
         Header unset Last-Modified #不使用http头信息中的Last-Modified属性,Last-Modified是指文件最后修改时间
     Header append Cache-Control public #设置为可被任何缓存区缓存
    </FilesMatch>
</IfModule>

具体配置内容可参考mod_expires模块手册

 

上面的配置是我自己的服务器上正在使用的配置方法,在这里与大家分享一下,代码不会有错,最后不要忘记重启apache服务器哦!

 

如果有apache高人有更好的配置,请指教一下!

如果用的虚拟主机,而虚拟主机支持.htaccess,则可以将上面的代码放到.htaccess文件中。

 

注:IIS下启用GZIP功能见Gzip压缩启用方法【IIS6.0、Apache】

分享到:
评论

相关推荐

    apache启用gzip压缩的实现方法

    【Apache启用Gzip压缩的实现方法】 Gzip是一种高效的文件压缩算法,广泛应用于Linux系统,尤其是在Web服务领域。它能够显著减小纯文本文件的大小,通常可将文件压缩70%以上,具体压缩比例取决于文件内容。Apache...

    Web2.0前端性能优化方案.pdf

    主流服务器如Apache支持开启GZIP压缩,只需在配置文件中启用mod_gzip或mod_deflate。注意,已压缩格式的图片不应再次压缩。 3. **CSS优先,JS延迟加载**:将CSS放在HTML头部,确保页面核心内容尽早显示。JavaScript...

    高流量Web2.0网站性能调优的14条准则

    大多数现代Web服务器支持Gzip,如Apache的mod_deflate模块,它能在不显著增加CPU负担的情况下提供良好的压缩效果。 5. 将样式表放在头部:将CSS文件放在`&lt;head&gt;`标签中,确保页面内容能逐步呈现,即使脚本未加载,...

    nginx替代方案,nginx代替apache与jboss

    - **带宽优化**:支持 GZIP 压缩,并能添加用于浏览器本地缓存的 Header 头,从而节省带宽资源。 - **高稳定性**:用于反向代理时,几乎不会发生宕机现象。 #### 实施步骤 1. **JBoss 配置文件修改**:取消 JBoss ...

    Nginx的相关配置

    以上内容总结了Nginx的一些核心配置知识点,包括其优点、依赖软件包、日志管理、安全性配置、版本号隐藏、缓存时间设置、连接超时配置以及压缩功能的启用。这些配置对于优化Nginx服务器的性能、增强安全性以及提高...

    WAP建站技术详解与实例.

    - **压缩内容**:使用GZIP等压缩技术减少数据传输量。 - **图片优化**:减小图片尺寸和质量,适应移动设备显示。 - **缓存利用**:合理设置缓存策略,减少重复内容的传输。 - **快速响应时间**:优化服务器性能...

    Jetty权威指南.pdf

    启用GZIP压缩可以减小传输的数据量,从而降低带宽使用和提高响应速度。 **13.5 Optimizing with Last-Modified and Cache-Control** 通过设置HTTP头部中的`Last-Modified`和`Cache-Control`字段,可以有效利用...

    常见请求和响应头-说明.doc

    3. Accept-Encoding:客户端告知服务器它支持的内容压缩编码类型,如gzip、compress。示例:Accept-Encoding: compress, gzip 4. Accept-Language:客户端可以接受的语言,如英语(en)或中文(zh)。示例:Accept-...

    常见请求和响应头-说明.docx

    3. Accept-Encoding: 指定浏览器可以支持的 web 服务器返回内容压缩编码类型,例如 Accept-Encoding: compress, gzip。 4. Accept-Language: 指定浏览器可接受的语言,例如 Accept-Language: en,zh。 5. Accept-...

    http请求与响应需要可以下载Requests部分

    3. **Accept-Encoding**: 客户端声明它可以处理的数据压缩格式,比如 `Accept-Encoding: compress, gzip` 表示客户端支持压缩编码的响应,例如gzip和compress。 4. **Accept-Language**: 客户端可以接受的语言排序...

Global site tag (gtag.js) - Google Analytics