如何开启Apache,Nginx和IIS服务器的GZIP压缩功能


Posted in Servers onApril 29, 2022

我们知道做好负载均衡对网站的正常运行,用户体验相当重要。在负载均衡中有一个必须要做的事情就是给服务器开启GZIP压缩功能,对用户请求的页面进行压缩处理,以达到节省网络带宽,提高网站速度的作用。

GZIP是若干文件压缩程序的简称,通常指GNU计划的实现,此处的GZIP代表的就是GUN ZIP,这也是HTTP1.1协议定义的两种压缩方法中最常用的一种压缩方法,客户端浏览器大都支持这种压缩格式。接下来,DNSLA将介绍apache、IIS、nginx 这些现在流行的web服务器如何开启GZIP压缩的方法。

Apache如何开启GZIP功能

Apache开启GZIP要看查看是否已经开启mod_deflate模块,如果没有则需要先加载,在配置文件httpd.conf中将

LoadModule deflate_module modules/mod_deflate.so

LoadModule headers_module modules/mod_headers.so

前面的#号去掉。DNSLA建议,如果对apache的配置文件不太懂的客户在修改配置文件之前对配置文件进行备份。

开启模块后,在httpd.conf配置文件的最下面空白处添加一下内容:

<IfModule mod_deflate.c>
# 告诉 apache 对传输到浏览器的内容进行压缩
SetOutputFilter DEFLATE
# 压缩等级 9
DeflateCompressionLevel 9
</IfModule>

这样就能对所有文件进行 gzip 压缩了。压缩等级是个 1-9 之间的整数,取值范围在 1(最低) 到 9(最高)之间,不建议设置太高,虽然有很高的压缩率,但是占用更多的CPU资源。

实际开发中我们并不需要对所有文件进行压缩,比如我们无需对图片文件进行gzip压缩,因为图片文件(一般为jpg、png等格式)本身已经压缩过了,再进行gzip压缩可能会适得其反(详见图片要启用gzip压缩吗?绝对不要!,背景图片千万不要gzip压缩,尤其是PNG),类似的还有 PDF 以及音乐文件。所以我们可以设置过滤指定文件或者对指定文件进行压缩。

比如我们要对图片等特殊文件不进行 gzip 压缩处理:

<IfModule mod_deflate.c>
# 告诉 apache 对传输到浏览器的内容进行压缩
SetOutputFilter DEFLATE
# 压缩等级 9
DeflateCompressionLevel 9
#设置不对后缀gif,jpg,jpeg,png的图片文件进行压缩
SetEnvIfNoCase Request_URI .(?:gif|jpe?g|png)$ no-gzip dont-vary
</IfModule>

或者指定文件格式进行压缩:

<IfModule mod_deflate.c>
# 压缩等级 9
DeflateCompressionLevel 9
# 压缩类型 html、xml、php、css、js
AddOutputFilterByType DEFLATE text/html text/plain text/xml application/x-javascript application/x-httpd-php
AddOutputFilter DEFLATE js css
</IfModule>

其中DeflateCompressionLevel 的意思是压缩等级,共分为1-9,9级为最高,不建议使用太高的压缩比,这样会对CPU产生太大的负担。

IIS如何开启GZIP功能

打开IIS管理工具,在右键网站打开网站属性,在服务选项卡中开启HTTP压缩,不建议选中压缩应用程序文件,但一定要选上压缩静态文件,不然就等于没有压缩,达不到负载均衡了。然后选中我那个站下面那个服务器扩展,新建一个服务器扩展,名字为GZIP,下面的添加文件路径为:c:\windows\system32\inetsrv\gzip.dll,然后启用这个扩展。DNSLA提醒大家,还没结束,第三步是,我们要修改配置文件,在配置文件之前要停止IIS服务,(DNSLA提醒大家一定要先关闭IIS服务)打开C:\Windows\System32\inetsrv\MetaBase.xml,这个文件很大,找到下面一段信息:

<IIsCompressionScheme  Location ="/LM/W3SVC/Filters/Compression/gzip"

HcCompressionDll="%windir%\system32\inetsrv\gzip.dll"

HcCreateFlags="1"

HcDoDynamicCompression="TRUE"

HcDoOnDemandCompression="TRUE"

HcDoStaticCompression="TRUE"

HcDynamicCompressionLevel="0"

HcFileExtensions="htm

html

txt"

HcOnDemandCompLevel="10"

HcPriority="1"

HcScriptFileExtensions="asp

dll

exe"

>

</IIsCompressionScheme>

修改这个文件是要增加一些要进行压缩的文件后缀,其中 HcFileExtensions 是静态文件的扩展名,增加 js 和 css 等;HcScriptFileExtensions 为动态文件的扩展名,增加 aspx,HcDynamicCompressionLevel改成9,(0-10,6是性价比最高的一个)。

然后需要重启一下IIS服务即可。

Nginx如何开启GZIP功能

相对apache 和 IIS nginx开启GZIP简单很多,只需要打开配置文件 nginx.conf找到gzip on 把前面的注释符号#去掉即可开启GZIP服务。然后配置GZIP即可。

下面是一个相对优化不错的配置,DNSLA建议使用。

Gzip on;

gzip_min_length 1024;

gzip_buffers   4  8k;

gzip_types   text/plain application/x-javascript text/css  application/xml;

到此这篇关于服务器端如何开启GZIP压缩功能(Apache、IIS、Nginx)的文章就介绍到这了!


Tags in this post...

Servers 相关文章推荐
Linux安装Nginx步骤详解
Mar 31 Servers
nginx 防盗链防爬虫配置详解
Mar 31 Servers
Windows下使用Nginx+Tomcat做负载均衡的完整步骤
Mar 31 Servers
nginx location优先级的深入讲解
Mar 31 Servers
Nginx缓存设置案例详解
Sep 15 Servers
nginx中封禁ip和允许内网ip访问的实现示例
Mar 17 Servers
Kubernetes部署实例并配置Deployment、网络映射、副本集
Apr 01 Servers
OpenStack虚拟机快照和增量备份实现方法
Apr 04 Servers
CentOS7环境下MySQL8常用命令小结
Jun 10 Servers
Windows server 2022创建创建林、域树、子域的步骤
Jun 25 Servers
win7配置本地ftp服务器的图文教程
Aug 05 Servers
Elasticsearch6.2服务器升配后的bug(避坑指南)
Sep 23 Servers
解决IIS7下无法绑定https主机的问题
IIS服务器中设置HTTP重定向访问HTTPS
在Windows Server 2012上安装 .NET Framework 3.5 所遇到的问题
解决Windows Server2012 R2 无法安装 .NET Framework 3.5
Windows Server 2012 R2 磁盘分区教程
Windows server 2012 R2 安装IIS服务器
安装Windows Server 2012 R2企业版操作系统并设置好相关参数
You might like
十天学会php之第九天
2006/10/09 PHP
PHP遍历二维数组的代码
2011/04/22 PHP
php获取服务器信息的实现代码
2013/02/04 PHP
利用PHP实现图片等比例放大和缩小的方法详解
2013/06/06 PHP
php 魔术方法详解
2014/11/11 PHP
Avengerls vs KG BO3 第二场2.18
2021/03/10 DOTA
google jQuery 引用文件,jQuery 引用地址集合(jquery 1.2.6至jquery1.5.2)
2011/04/24 Javascript
解析使用JS 清空File控件的路径值
2013/07/08 Javascript
js使下拉列表框可编辑不止是选择
2013/12/12 Javascript
jquery鼠标放上去显示悬浮层即弹出定位的div层
2014/04/25 Javascript
使用jsonp实现跨域获取数据实例讲解
2016/12/25 Javascript
bootstrap vue.js实现tab效果
2017/02/07 Javascript
从零学习node.js之express入门(六)
2017/02/25 Javascript
Node.js服务器开启Gzip压缩教程
2017/08/11 Javascript
Vue.js移动端左滑删除组件的实现代码
2017/09/08 Javascript
浅谈Vue SPA 首屏加载优化实践
2017/12/15 Javascript
angularjs数组判断是否含有某个元素的实例
2018/02/27 Javascript
解决vue中无法动态修改jqgrid组件 url地址的问题
2018/03/01 Javascript
vue 组件中添加样式不生效的解决方法
2018/07/06 Javascript
JS/HTML5游戏常用算法之路径搜索算法 随机迷宫算法详解【普里姆算法】
2018/12/13 Javascript
jQuery实现移动端图片上传预览组件的方法分析
2020/05/01 jQuery
基于Vue CSR的微前端实现方案实践
2020/05/27 Javascript
微信小程序实现电子签名功能
2020/07/29 Javascript
[46:55]LGD vs Liquid 2019国际邀请赛小组赛 BO2 第一场 8.16
2019/08/19 DOTA
Python简单计算文件夹大小的方法
2015/07/14 Python
Python基础教程之浅拷贝和深拷贝实例详解
2017/07/15 Python
使用Pycharm(Python工具)新建项目及创建Python文件的教程
2020/04/26 Python
Python函数递归调用实现原理实例解析
2020/08/11 Python
The Outnet亚太地区:折扣设计师时装店
2019/12/05 全球购物
团支书的期末学习总结自我评价
2013/11/01 职场文书
运动会入场解说词300字
2014/01/25 职场文书
迟到检讨书500字
2014/02/05 职场文书
《逃家小兔》教学反思
2014/02/23 职场文书
普宁寺导游词
2015/02/04 职场文书
小学少先队活动总结
2015/05/08 职场文书
使用CSS实现百叶窗效果示例代码
2023/05/07 HTML / CSS