主机论坛_虚拟主机_美国主机_美国虚拟主机_云主机技术_全球主机交流聚集地—Web Hosting Talk 中文站

找回密码
立即注册
发新帖

0

收听

5

听众

991

主题
发表于 2022-1-21 14:29:41 | 查看: 79| 回复: 0

最近生产上发生了一些问题,原先所有的静态资源文件都是经过gzip压缩的,然而这几天突然都没有压缩了,经过一顿排查,发现是Nginx的配置有问题,借此机会详细了解了NginxGzip配置。

1. Nginx开启Gzip1.1 配置说明1.2 参数详解gzip ongzip_buffersgzip_comp_levelgzip_disablegzip_min_lengthgzip_http_versiongzip_proxiedgzip_typesgzip_vary

1. Nginx开启GzipNginx实现资源压缩的原理是通过ngx_http_gzip_module模块拦截请求,并对需要做gzip的类型做gzipngx_http_gzip_moduleNginx默认集成的,不需要重新编译,直接开启即可。
1.1 配置说明Nginx开启Gzip的配置如下:
# $gzip_ratio计算请求的压缩率,$body_bytes_sent请求体大小 log_format  main  '$remote_addr - $remote_user [$time_local] "$host" - "$request" '                    '$gzip_ratio - $body_bytes_sent - $request_time';    access_log  logs/access.log main; # 开启gzip gzip off; # 启用gzip压缩的最小文件,小于设置值的文件将不会压缩 gzip_min_length 1k; # gzip 压缩级别,1-9,数字越大压缩的越好,也越占用CPU时间,后面会有详细说明 gzip_comp_level 1; # 进行压缩的文件类型。javascript有多种形式。其中的值可以在 mime.types 文件中找到。 gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png application/vnd.ms-fontobject font/ttf font/opentype font/x-woff image/svg+xml; # 是否在http header中添加Vary: Accept-Encoding,建议开启 gzip_vary on; # 禁用IE 6 gzip gzip_disable "MSIE [1-6]\."; # 设置压缩所需要的缓冲区大小  gzip_buffers 32 4k; # 设置gzip压缩针对的HTTP协议版本 gzip_http_version 1.0;123456789101112131415161718192021222324252627282930下面将逐条介绍下gzip的指令和参数配置。
1.2 参数详解gzip on这个没的说,打开或关闭gzip
Syntax: gzip on | off; Default:    gzip off;Context:    http, server, location, if in location 12345gzip_buffers设置用于处理请求压缩的缓冲区数量和大小。比如32 4K表示按照内存页(one memory page)大小以4K为单位(即一个系统中内存页为4K),申请32倍的内存空间。建议此项不设置,使用默认值。
Syntax: gzip_buffers number size; Default:    gzip_buffers 32 4k|16 8k; Context:    http, server, location1234gzip_comp_level设置gzip压缩级别,级别越底压缩速度越快文件压缩比越小,反之速度越慢文件压缩比越大
Syntax: gzip_comp_level level; Default:    gzip_comp_level 1; Context:    http, server, location 12345我们以一个大小为92.6K的脚本文件为例,如下所示。其中最后三个数值分别表示压缩比、包大小、平均处理时间(使用ab压测,100用户并发下,//10.27.180.75/jquery.js  gzip_comp_level 0: 094840, 63 [ms], 29%gzip_comp_level 1: 2.4339005, 248 [ms], 100%gzip_comp_level 2: 2.5137743, 273 [ms], 100%gzip_comp_level 3; 2.5736849, 327 [ms], 100%gzip_comp_level 4; 2.7334807, 370 [ms], 100%gzip_comp_level 5; 2.8033898, 491 [ms], 100%gzip_comp_level 6; 2.8233686, 604 [ms], 100%gzip_comp_level 7; 2.8233626, 659 [ms], 100%gzip_comp_level 8; 2.8233626, 698 [ms], 100%gzip_comp_level 9; 2.8233626, 698 [ms], 100%1234567891011gzip_disable通过表达式,表明哪些UA头不使用gzip压缩
Syntax: gzip_disable regex ...;Default:    —Context:    http, server, locationThis directive appeared in version 0.6.23.1234gzip_min_length当返回内容大于此值时才会使用gzip进行压缩,K为单位,当值为0时,所有页面都进行压缩。
Syntax: gzip_min_length length; Default:    gzip_min_length 20; Context:    http, server, location1234gzip_http_version用于识别http协议的版本,早期的浏览器不支持gzip压缩,用户会看到乱码,所以为了支持前期版本加了此选项。默认在http/1.0的协议下不开启gzip压缩。
Syntax: gzip_http_version 1.0 | 1.1; Default:    gzip_http_version 1.1; Context:    http, server, location1234我看网上的很多文章中,对这一点都觉得过时了,因为浏览器基本上都支持HTTP/1.1。然而这里面却存在着一个很容易掉入的坑,也是笔者从生产环境中一个诡异问题中发现的:为什么这样呢?我相信,以后还有人会入坑,比如你用Apache ab做压测,如果不是设置gzip_http_version1.0,你也压不出gzip的效果(同样的道理)。希望写在这里对大家有帮助
gzip_proxiedNginx做为反向代理的时候启用:
off – 关闭所有的代理结果数据压缩expired – 如果header中包含”Expires”头信息,启用压缩no-cache – 如果header中包含”Cache-Control:no-cache”头信息,启用压缩no-store – 如果header中包含”Cache-Control:no-store”头信息,启用压缩private – 如果header中包含”Cache-Control:private”头信息,启用压缩no_last_modified – 启用压缩,如果header中包含”Last_Modified”头信息,启用压缩no_etag – 启用压缩,如果header中包含“ETag”头信息,启用压缩auth – 启用压缩,如果header中包含“Authorization”头信息,启用压缩any – 无条件压缩所有结果数据Syntax: gzip_proxied off | expired | no-cache | no-store | private | no_last_modified | no_etag | auth | any ...;Default:    gzip_proxied off;Context:    http, server, location1234gzip_types设置需要压缩的MIME类型,如果不在设置类型范围内的请求不进行压缩
Syntax: gzip_types mime-type ...;Default:    gzip_types text/html;Context:    http, server, location1234这里需要说明一些特殊的类型,比如笔者公司会使用字体类型的资源,而这些资源类型往往会被忽略,且这些资源又比较大,没有被压缩很不合算。:字体类型扩展名Content-type.eotapplication/vnd.ms-fontobject.ttffont/ttf.otffont/opentype.wofffont/x-woff.svgimage/svg+xmlgzip_vary增加响应头”Vary: Accept-Encoding”
Syntax: gzip_vary on | off; Default:    gzip_vary off;Context:    http, server, location 12345


云专线 海外专线 http://www.vecloud.com

收藏回复 显示全部楼层 道具 举报

您需要登录后才可以回帖 登录 | 立即注册

Archiver|手机版|小黑屋|WebHostingTalk中文站

GMT+8, 2024-5-5 14:29 , Processed in 0.069136 second(s), 23 queries .

Powered by Discuz! X3.4

Copyright © 2001-2024, Tencent Cloud.

快速回复 返回顶部 返回列表