Nginx开启gzip

1. ngx_http_gzip_module

ngx_http_gzip_module是nginx中堆响应以gzip方式进行压缩的一个拦截器,以减少传输数据的大小。

配置示例:

gzip on;
gzip_min_length  5k;
gzip_buffers     4 16k;
gzip_http_version 1.0;
gzip_comp_level 3;
gzip_types       text/plain application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png;
gzip_vary on;

2. 配置项说明

gzip on/off
Syntax:	gzip on | off;
Default:	gzip off;
Context:	http, server, location, if in location

开启/关闭gzip

gzip_buffers
Syntax:	gzip_buffers number size;
Default:	gzip_buffers 32 4k|16 8k;
Context:	http, server, location

设置系统获取几个单位的缓存用于存储gzip的压缩结果数据流。 例如 4 4k 代表以4k为单位,按照原始数据大小以4k为单位的4倍申请内存。 4 8k 代表以8k为单位,按照原始数据大小以8k为单位的4倍申请内存。如果没有设置,默认值是申请跟原始数据相同大小的内存空间去存储gzip压缩结果。

gzip_comp_level
Syntax:	gzip_comp_level level;
Default:	gzip_comp_level 1;
Context:	http, server, location

设置压缩级别,可接受的值有1-9。数字越大压缩比越高,同时对CPU的消耗也越大。一般建议设置成4-5。下面是一张压缩比的图可做参考(图片来源:https://seo.g2soft.net/2015/11/19/nginx-gzip-comp-level.html):

gzip_comp_level_difference.png

gzip_disable
Syntax:	gzip_disable regex ...;
Default:	—
Context:	http, server, location
This directive appeared in version 0.6.23.

匹配User-Agent头部信息决定哪些内容不需要压缩。

gzip_http_version
Syntax:	gzip_http_version 1.0 | 1.1;
Default:	gzip_http_version 1.1;
Context:	http, server, location

设置最低的需要压缩的HTTP协议版本。由于早期的浏览器不支持gzip压缩,压缩之后会乱码。

gzip_min_length
Syntax:	gzip_min_length length;
Default:	gzip_min_length 20;
Context:	http, server, location

设置最小的需要压缩的内容长度,小于该值的内容不会进行压缩。1k表示小于1k的内容不进行压缩。

gzip_proxied
Syntax:	gzip_proxied off | expired | no-cache | no-store | private | no_last_modified | no_etag | auth | any ...;
Default:	gzip_proxied off;
Context:	http, server, location

Nginx作为反向代理的时候启用,根据某些请求和应答来决定是否在对代理请求的应答启用gzip压缩,是否压缩取决于请求头中的“Via”字段,指令中可以同时指定多个不同的参数,意义如下:

  • 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 - 无条件启用压缩
gzip_types
Syntax:	gzip_types mime-type ...;
Default:	gzip_types text/html;
Context:	http, server, location

指定压缩的MIME类型。

gzip_vary
Syntax:	gzip_vary on | off;
Default:	
gzip_vary off;
Context:	http, server, locatio

和http头有关系,加个vary头,给代理服务器用的,有的浏览器支持压缩,有的不支持,所以避免浪费不支持的也压缩,所以根据客户端的HTTP头来判断,是否需要压缩。

参考文章

posted @ 2020-09-20 21:56  六月瓜  阅读(128)  评论(0编辑  收藏  举报