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配置ssl实现https的方法示例
Mar 31 Servers
nginx proxy_cache 缓存配置详解
Mar 31 Servers
Nginx解决403 forbidden的完整步骤
Apr 01 Servers
uwsgi+nginx代理Django无法访问静态资源的解决
May 10 Servers
nginx配置文件使用环境变量的操作方法
Jun 02 Servers
Nginx源码编译安装过程记录
Nov 17 Servers
Nginx 反向代理解决跨域问题多种情况分析
Jan 18 Servers
Tomcat starup.bat 脚本实现开机自启动
Apr 20 Servers
Tomcat执行startup.bat出现闪退的原因及解决办法
Apr 20 Servers
Linux安装Docker详细教程
Jul 07 Servers
CentOS7设置ssh服务以及端口修改方式
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
日本十大惊悚动漫
2020/03/04 日漫
PHP通过插入mysql数据来实现多机互锁实例
2014/11/05 PHP
php 实现一个字符串加密解密的函数实例代码
2016/11/01 PHP
ThinkPhP+Apache+PHPstorm整合框架流程图解
2020/11/23 PHP
javascript当onmousedown、onmouseup、onclick同时应用于同一个标签节点Element
2010/01/05 Javascript
Select标签下拉列表二级联动级联实例代码
2014/02/07 Javascript
解决JS请求服务器gbk文件乱码的问题
2015/10/16 Javascript
深入学习JavaScript的AngularJS框架中指令的使用方法
2016/03/05 Javascript
修改jquery中dialog的title属性方法(推荐)
2016/08/26 Javascript
node.js(express)中使用Jcrop进行图片剪切上传功能
2017/04/21 Javascript
学习使用Bootstrap输入框、导航、分页等常用组件
2017/05/11 Javascript
JavaScript对JSON数据进行排序和搜索
2017/07/24 Javascript
JavaScript高级函数应用之分时函数实例分析
2018/08/03 Javascript
vue实现同一个页面可以有多个router-view的方法
2018/09/20 Javascript
vue+webpack 更换主题N种方案优劣分析
2019/10/28 Javascript
vue $set 给数据赋值的实例
2019/11/09 Javascript
js实现移动端轮播图滑动切换
2020/12/21 Javascript
[07:25]DOTA2-DPC中国联赛2月5日Recap集锦
2021/03/11 DOTA
使用Python中PDB模块中的命令来调试Python代码的教程
2015/03/30 Python
python使用post提交数据到远程url的方法
2015/04/29 Python
Python实现身份证号码解析
2015/09/01 Python
利用Python批量压缩png方法实例(支持过滤个别文件与文件夹)
2017/07/30 Python
Windows下PyCharm安装图文教程
2018/08/27 Python
python微信好友数据分析详解
2018/11/19 Python
pygame游戏之旅 按钮上添加文字的方法
2018/11/21 Python
python3 BeautifulSoup模块使用字典的方法抓取a标签内的数据示例
2019/11/28 Python
python3+opencv生成不规则黑白mask实例
2020/02/19 Python
使用HTML5做的导航条详细步骤
2020/10/19 HTML / CSS
美国现代家具和家居商店:Apt2B
2016/08/29 全球购物
TUMI澳大利亚网站:美国旅行箱包品牌
2017/03/27 全球购物
世嘉游戏英国官方商店:SEGA Shop UK
2019/09/20 全球购物
Linux面试经常问的文件系统操作命令
2016/10/04 面试题
升旗仪式主持词
2014/03/19 职场文书
欢迎领导标语
2014/06/27 职场文书
公安四风对照检查材料思想汇报
2014/10/11 职场文书
angular异步验证器防抖实例详解
2022/03/31 Javascript