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
利用Nginx代理如何解决前端跨域问题详析
Apr 02 Servers
nginx配置文件使用环境变量的操作方法
Jun 02 Servers
Tomcat用户管理的优化配置详解
Mar 31 Servers
CentOS7和8下安装Maven3.8.4
Apr 07 Servers
从零开始在Centos7上部署SpringBoot项目
Apr 07 Servers
CentOS安装Nginx并部署vue
Apr 12 Servers
如何开启Apache,Nginx和IIS服务器的GZIP压缩功能
Apr 29 Servers
shell进度条追踪指令执行时间的场景分析
Jun 16 Servers
win sever 2022如何占用操作主机角色
Jun 25 Servers
Windows7下FTP搭建图文教程
Aug 05 Servers
nginx sticky实现基于cookie负载均衡示例详解
Dec 24 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
PHP进程通信基础之信号
2017/02/19 PHP
PHP四种排序算法实现及效率分析【冒泡排序,插入排序,选择排序和快速排序】
2018/04/27 PHP
javascript定义函数的方法
2010/12/06 Javascript
JS对HTML标签select的获取、添加、删除操作
2013/10/17 Javascript
javascript中的previousSibling和nextSibling的正确用法
2015/09/16 Javascript
深入理解JQuery中的事件与动画
2016/05/18 Javascript
jQuery+ajax实现滚动到页面底部自动加载图文列表效果(类似图片懒加载)
2016/06/07 Javascript
全面解析Bootstrap表单样式的使用
2016/09/09 Javascript
详解jQuery中基本的动画方法
2016/12/14 Javascript
JS中如何实现Laravel的route函数详解
2017/02/12 Javascript
angular ng-repeat数组中的数组实例
2017/02/18 Javascript
详解Javascript获取缓存和清除缓存API
2017/05/25 Javascript
webpack打包js文件及部署的实现方法
2017/12/18 Javascript
vuex 实现getter值赋值给vue组件里的data示例
2019/11/05 Javascript
[01:31:22]Ti4 循环赛第四日附加赛LGD vs Mouz
2014/07/13 DOTA
Python实现的简单算术游戏实例
2015/05/26 Python
Python 实现简单的电话本功能
2015/08/09 Python
Python 基础教程之包和类的用法
2017/02/23 Python
python实现windows壁纸定期更换功能
2019/01/21 Python
python使用PyQt5的简单方法
2019/02/27 Python
使用PYTHON解析Wireshark的PCAP文件方法
2019/07/23 Python
Python3 Click模块的使用方法详解
2020/02/12 Python
python使用matplotlib:subplot绘制多个子图的示例
2020/09/24 Python
CSS3中31种选择器使用方法教程
2013/12/05 HTML / CSS
Html5原生拖拽相关事件简介以及基础实现
2020/11/19 HTML / CSS
科颜氏加拿大官方网站: Kiehl’s加拿大
2016/08/16 全球购物
高中的自我鉴定
2013/12/16 职场文书
黄继光的英雄事迹材料
2014/02/13 职场文书
局火灾防控工作方案
2014/05/25 职场文书
市级青年文明号申报材料
2014/05/26 职场文书
人身损害赔偿协议书范本
2014/09/27 职场文书
长城英文导游词
2015/01/30 职场文书
实习单位推荐信
2015/03/27 职场文书
工程质检员岗位职责
2015/04/08 职场文书
2015年测量员工作总结
2015/05/23 职场文书
导游词之唐山景点
2019/12/18 职场文书