1. 为何要进行gzip压缩?javascript
服务器设置 gzip 压缩是 web 开发中很广泛的作法。使用gzip压缩后可使须要加载的文件大小缩小到原来的1/4左右(最大压缩级别)。而后在客户端解压便可。php
2.如何在Apache中开启gzip压缩服务?css
wamp为例:html
2.1 找到Apache中的httpd.conf文件,好比个人路径在D:\wamp\bin\apache\apache2.4.35\conf\httpd.confjava
2.2 在编辑器中打开httpd.conf文件,找到deflate_Module和headers_Module这两个模块。去掉注释开启服务。(大概在第120行和130行左右)web
#LoadModule deflate_module modules/mod_deflate.so
#LoadModule headers_module modules/mod_headers.so
我测试过#LoadModule headers_module modules/mod_headers.so这个模块即便不修改也能实现gzip压缩服务。但不少资料都说这两行要同时去掉注释,否则网页显示不正常。
2.3 开启上面的服务后在httpd.conf文件最后加上下面代码,而后重启Apache就好了:apache
## 使用<IfModule deflate_module> 和 <IfModule mod_deflate.c> 通过测试没什么区别浏览器
<IfModule deflate_module>
# 就像一个开关同样,告诉 Apache 对传输到浏览器的内容进行压缩
SetOutputFilter DEFLATE
# 压缩级别 9是最高级 1是最低级,不建议使用过高的压缩比,这样会对CPU产生太大的负担
DeflateCompressionLevel 9
</IfModule>服务器
2.4 注意,完成上面的步骤就能够实现gzip压缩了。可是上面的压缩是对全部的文件都进行了压缩,但在实际的开发过程当中并不须要对全部文件都进行压缩,好比PDF 、图片、音乐文档之类的这些自己都已经高度压缩格式,重复压缩的做用不大,反而可能会由于增长CPU的处理时间及浏览器的渲染问题而下降性能。因此就不必再经过Gzip压缩。app
3. 设置过滤指定文件或者对指定文件进行压缩
3.1 对图片等特殊文件不进行 gzip 压缩处理:
<IfModule mod_deflate.c> # 告诉 apache 对传输到浏览器的内容进行压缩 SetOutputFilter DEFLATE # 压缩等级 9 最低是1,不建议按最大级别进行压缩,压缩率太高会占更多CPU资源 DeflateCompressionLevel 9 # 设置不对后缀gif,jpg,jpeg,png的图片文件进行压缩 SetEnvIfNoCase Request_URI .(?:gif|jpe?g|png)$ no-gzip dont-vary </IfModule>
3.2 指定文件进行压缩
<IfModule mod_deflate.c> # 压缩等级 9 DeflateCompressionLevel 9 # 压缩类型 html、xml、php、css、js 面的文件MIME类型能够根据本身状况添加 AddOutputFilterByType DEFLATE text/html text/plain text/xml application/x-javascript application/x-httpd-php AddOutputFilter DEFLATE js css </IfModule>
4. 备注
参考:
如何使用gzip压缩:https://www.cnblogs.com/zichi/p/5030877.html
gzip和deflate压缩:https://blog.csdn.net/xjbclz/article/details/52474114