Nginx的gzip相关介绍


Posted in Servers onMay 11, 2022

简介

GZIP顾名思义,就是将文件压缩传输。图片、视频、大文件不建议使用压缩,压缩需要占用你的服务器资源,压缩完效果也不大。文章出现很多图片的话,我建议使用图床来存放你的图片。文章给大家介绍Nginx的gzip指令。

说一段废话

压缩响应数据有什么作用呢?问的好:从用户体验和IT成本两方面回答这个问题:

  • 用户体验上

网速一定的情况下,传输5MB数据比传输10MB数据的时间快了一半。所以传输数据越小用户加载页面就越快,当然相比较之下体验会更好。

  • IT成本上

对这个场景来说的成本主要是带宽成本, 数据不压缩那么传输这些数据相应的带宽肯定更大,对比之下压缩耗费的CPU资源在带宽费用上不值一提。

所以你有什么理由不用压缩呢?

背景

当然Nginx也提供了gzip的压缩方式可以使用,但是在日常的工作中我发现或多或少在使用上有些问题,有点像:用了但又好像没用的感觉。 这篇就记录一下gzip的使用方式和易错点。

指令介绍

gzip

gzip指令来自 ngx_http_gzip_module 模块,提供的核心能力就是压缩响应数据。

该模块下提供的指令如下:

gzip                on;     # 开启gzip
gzip_comp_level     6;      # 压缩等级:1-9 1:压缩最快/CPU消耗最少/压缩率最低 以次类推
gzip_min_length     1000;   # 小于此大小的数据不压缩(单位字节/byte);数据来源"Content-Length"头
gzip_buffers        32 4k;  # 压缩响应的缓冲区数量和大小(4K 内存页大小取决于平台)
gzip_proxied        any;    # 对代理的请求是否开启压缩
gzip_types text/plain application/xml application/javascript application/x-javascript text/css application/json;    # 哪些类型的数据需要被压缩
gzip_disable     "MSIE [1-5]\.";    # User-Agent 被正则匹配到的不开启压缩
gzip_vary on;               # 当gzip对请求生效时会被添加一个响应头 "Vary: Accept-Encoding"

tips:

  1. gzip 是动态压缩: 每个请求在被响应时都会在gzip逻辑内走一遍
  2. 压缩等级不是越高越好: 压缩到一定程度后就会吃力不讨好, 从js的测试来看性价比最高的级别是 5或6
  3. buffer大小设置最好是和平台的内存页保持一致: getconf PAGE_SIZE
  4. gzip_types不要瞎写: 写压缩率大的(css/js/xml/json/ttf), image图片就不要写了,压缩空间太小,又耗CPU

gzip_static

gzip_stati指令来自 ngx_http_gzip_static_module模块,提供的核心能力是静态/预压缩

该模块提供的指令如下:

gzip_static on|off|always;  # always: 不管客户端是否支持压缩我他妈全部给你压缩之后给你

 

tips:

  1. 可以复用gzip_module中以下的指令:

gzip_http_version, gzip_proxied, gzip_disable, gzip_vary

  1. gzip_static是静态压缩:意思是你的服务端需要同时存在源文件和使用gzip压缩后的源文件,这时请求的时候会优先吧压缩文件返回,这样就不用再耗费CPU去动态压缩了。(视情况来用,我们没用)
  2. 可以和gzip一同开启,没啥影响,它的优先级高于gzip

易错点提示

在实际的生产环境中架构都比较负载,不像一个单纯的Nginx一样,我配置好了就万事大吉了。

时常会遇到有些网站明明配置了gzip但是展示上看并没有生效,为什么?

此时需要梳理这个请求流程,看看这个请求都经过了哪些地方,比如 你的请求通过三次代理(CDN-->Nginx-->Nginx)那么在其中一层没有配置或者配置错误那么整体的返回数据就是没有被压缩的, 这种情况出现还是比较多的。

 


Tags in this post...

Servers 相关文章推荐
Nginx快速入门教程
Mar 31 Servers
Windows下使用Nginx+Tomcat做负载均衡的完整步骤
Mar 31 Servers
解析在浏览器地址栏输入一个URL后发生了什么
Jun 21 Servers
Apache Hudi集成Spark SQL操作hide表
Mar 31 Servers
如何通过cmd 连接阿里云服务器
Apr 18 Servers
nginx rewrite功能使用场景分析
May 30 Servers
永中文档在线转换预览基于nginx配置部署方案
Jun 10 Servers
Nginx开源可视化配置工具NginxConfig使用教程
Jun 21 Servers
Nginx报404错误的详细解决方法
Jul 23 Servers
Nginx如何配置根据路径转发详解
Jul 23 Servers
Windows server 2016服务器基本设置
Aug 14 Servers
详解如何使用Nginx解决跨域问题
May 06 #Servers
配置nginx负载均衡
May 06 #Servers
tomcat下部署jenkins的方法
排查Tomcat进程假死的问题
May 06 #Servers
使用Nginx的访问日志统计PV与UV
Tomcat配置访问日志和线程数
May 06 #Servers
tomcat正常启动但网页却无法访问的几种解决方法
May 06 #Servers
You might like
使用zend studio for eclipse不能激活代码提示功能的解决办法
2009/10/11 PHP
php 获取一个月第一天与最后一天的代码
2010/05/16 PHP
PHP目录函数实现创建、读取目录教程实例
2011/01/13 PHP
PHP中file_exists与is_file,is_dir的区别介绍
2012/09/12 PHP
PHP中使用socket方式GET、POST数据实例
2015/04/02 PHP
Laravel-admin之修改操作日志的方法
2019/09/30 PHP
js类 from qq
2006/11/13 Javascript
js 三级关联菜单效果实例
2013/08/13 Javascript
实现placeholder效果的方案汇总
2015/06/11 Javascript
详解AngularJS中module模块的导入导出
2015/12/10 Javascript
学习JavaScript设计模式之观察者模式
2020/04/22 Javascript
AngularJS ng-blur 指令详解及简单实例
2016/07/30 Javascript
如何写好你的JavaScript【推荐】
2017/03/02 Javascript
使用jQuery,Angular实现登录界面验证码详解
2017/04/27 jQuery
Angular4学习笔记之新建项目的方法
2017/07/18 Javascript
快速解决vue-cli不能初始化webpack模板的问题
2018/03/20 Javascript
解决bootstrap-select 动态加载数据不显示的问题
2018/08/10 Javascript
vue中多个倒计时实现代码实例
2019/03/27 Javascript
js实现星星海特效的示例
2020/09/28 Javascript
浅谈nuxtjs校验登录中间件和混入(mixin)
2020/11/06 Javascript
[03:24]DOTA2超级联赛专访hao 大翻盘就是逆袭
2013/05/24 DOTA
Python中的rjust()方法使用详解
2015/05/19 Python
python简易实现任意位数的水仙花实例
2018/11/13 Python
Pandas读取并修改excel的示例代码
2019/02/17 Python
pytorch 在sequential中使用view来reshape的例子
2019/08/20 Python
详解Django-channels 实现WebSocket实例
2019/08/22 Python
python利用openpyxl拆分多个工作表的工作簿的方法
2019/09/27 Python
PyCharm GUI界面开发和exe文件生成的实现
2020/03/04 Python
Python生成随机验证码代码实例解析
2020/06/09 Python
ProBikeKit澳大利亚:自行车套件,跑步和铁人三项装备
2016/11/30 全球购物
英国奢侈品在线精品店:Hervia
2020/09/03 全球购物
YII2 全局异常处理深入讲解
2021/03/24 PHP
开水果连锁店创业计划书
2013/12/29 职场文书
反对形式主义、官僚主义、享乐主义和奢靡之风整改措施
2014/09/17 职场文书
幼儿园师德师风心得体会
2016/01/12 职场文书
创业计划书之酒店
2019/08/30 职场文书