先谈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压缩的实现方法】 Gzip是一种高效的文件压缩算法,广泛应用于Linux系统,尤其是在Web服务领域。它能够显著减小纯文本文件的大小,通常可将文件压缩70%以上,具体压缩比例取决于文件内容。Apache...
主流服务器如Apache支持开启GZIP压缩,只需在配置文件中启用mod_gzip或mod_deflate。注意,已压缩格式的图片不应再次压缩。 3. **CSS优先,JS延迟加载**:将CSS放在HTML头部,确保页面核心内容尽早显示。JavaScript...
大多数现代Web服务器支持Gzip,如Apache的mod_deflate模块,它能在不显著增加CPU负担的情况下提供良好的压缩效果。 5. 将样式表放在头部:将CSS文件放在`<head>`标签中,确保页面内容能逐步呈现,即使脚本未加载,...
- **带宽优化**:支持 GZIP 压缩,并能添加用于浏览器本地缓存的 Header 头,从而节省带宽资源。 - **高稳定性**:用于反向代理时,几乎不会发生宕机现象。 #### 实施步骤 1. **JBoss 配置文件修改**:取消 JBoss ...
以上内容总结了Nginx的一些核心配置知识点,包括其优点、依赖软件包、日志管理、安全性配置、版本号隐藏、缓存时间设置、连接超时配置以及压缩功能的启用。这些配置对于优化Nginx服务器的性能、增强安全性以及提高...
Java数组倒置 简单 Java图片加水印,支持旋转和透明度设置 摘要:Java源码,文件操作,图片水印 util实现Java图片水印添加功能,有添加图片水印和文字水印,可以设置水印位置,透明度、设置对线段锯齿状边缘处理、水印...
- **压缩内容**:使用GZIP等压缩技术减少数据传输量。 - **图片优化**:减小图片尺寸和质量,适应移动设备显示。 - **缓存利用**:合理设置缓存策略,减少重复内容的传输。 - **快速响应时间**:优化服务器性能...
启用GZIP压缩可以减小传输的数据量,从而降低带宽使用和提高响应速度。 **13.5 Optimizing with Last-Modified and Cache-Control** 通过设置HTTP头部中的`Last-Modified`和`Cache-Control`字段,可以有效利用...
3. Accept-Encoding:客户端告知服务器它支持的内容压缩编码类型,如gzip、compress。示例:Accept-Encoding: compress, gzip 4. Accept-Language:客户端可以接受的语言,如英语(en)或中文(zh)。示例:Accept-...
3. Accept-Encoding: 指定浏览器可以支持的 web 服务器返回内容压缩编码类型,例如 Accept-Encoding: compress, gzip。 4. Accept-Language: 指定浏览器可接受的语言,例如 Accept-Language: en,zh。 5. Accept-...
3. **Accept-Encoding**: 客户端声明它可以处理的数据压缩格式,比如 `Accept-Encoding: compress, gzip` 表示客户端支持压缩编码的响应,例如gzip和compress。 4. **Accept-Language**: 客户端可以接受的语言排序...