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 相关文章推荐
Apache压力测试工具的安装使用
Mar 31 Servers
Nginx快速入门教程
Mar 31 Servers
nginx网站服务如何配置防盗链(推荐)
Mar 31 Servers
详解Nginx启动失败的几种错误处理
Apr 01 Servers
Nginx URL重写rewrite机制原理及使用实例
Apr 01 Servers
nginx的zabbix 5.0安装部署的方法步骤
Jul 16 Servers
Nginx实现会话保持的两种方式
Mar 18 Servers
Nginx动静分离配置实现与说明
Apr 07 Servers
nginx.conf配置文件结构小结
Apr 08 Servers
Windows server 2012 配置Telnet以及用法详解
Apr 28 Servers
永中文档在线转换预览基于nginx配置部署方案
Jun 10 Servers
zabbix如何添加监控主机和自定义监控项
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
星际实力自我测试
2020/03/04 星际争霸
php检测文本的编码
2015/07/26 PHP
thinkPHP通用控制器实现方法示例
2017/11/23 PHP
YII2框架中ActiveDataProvider与GridView的配合使用操作示例
2020/03/18 PHP
详细介绍8款超实用JavaScript框架
2013/10/25 Javascript
JavaScript检查某个function是否是原生代码的方法
2014/08/20 Javascript
jQuery实现炫酷的鼠标轨迹特效
2015/02/01 Javascript
分享9点个人认为比较重要的javascript 编程技巧
2015/04/27 Javascript
jQuery实现点击后标记当前菜单位置(背景高亮菜单)效果
2015/08/22 Javascript
jQuery实现HTML表格单元格的合并功能
2016/04/06 Javascript
Bootstrap每天必学之模态框(Modal)插件
2016/04/26 Javascript
浏览器兼容的JS写法总结
2016/04/27 Javascript
BootStrap 模态框实现刷新网页并关闭功能
2017/01/04 Javascript
JS实现汉字与Unicode码相互转换的方法详解
2017/04/28 Javascript
Node.js log4js日志管理详解
2018/07/31 Javascript
使用Vue做一个简单的todo应用的三种方式的示例代码
2018/10/20 Javascript
Vue.js 无限滚动列表性能优化方案
2019/12/02 Javascript
JS原型和原型链原理与用法实例详解
2020/02/05 Javascript
谈一谈vue请求数据放在created好还是mounted里好
2020/07/27 Javascript
Vue 简单实现前端权限控制的示例
2020/12/25 Vue.js
[02:04]2020年夜魇暗潮预告片
2020/10/30 DOTA
Python中模拟enum枚举类型的5种方法分享
2014/11/22 Python
Python简单实现Base64编码和解码的方法
2017/04/29 Python
python实现名片管理系统项目
2019/04/26 Python
使用python-opencv读取视频,计算视频总帧数及FPS的实现
2019/12/10 Python
Python命令行click参数用法解析
2019/12/19 Python
python中的selenium安装的步骤(浏览器自动化测试框架)
2020/03/17 Python
理肤泉俄罗斯官网:La Roche-Posay俄罗斯
2018/07/24 全球购物
师范类求职信
2014/06/21 职场文书
三问三解心得体会
2014/09/05 职场文书
学习朴航瑛老师爱岗敬业先进事迹思想汇报
2014/09/17 职场文书
学校师德师风整改措施
2014/10/27 职场文书
三八妇女节新闻稿
2015/07/17 职场文书
Redis Stream类型的使用详解
2021/11/11 Redis
Win11 25163.1010更新补丁KB5016904推送,测试服务验证管道(附更新修复汇总)
2022/07/23 数码科技
IDEA中sout快捷键无效问题的解决方法
2022/07/23 Java/Android