1 介绍
压缩响应通常显著的减少传输数据的大小。然而,压缩发生在运行时,它也会增加相当大的处理开销对性能有负面的影响。Nginx在发送响应到客户端时执行压缩,但不对已经压缩的响应“二次压缩”。
2 启用压缩
为了启用压缩,设置gzip指令为on:
gzip on;
默认,Nginx只压缩MIME为text/html类型的响应。为了压缩其它MIME类型的响应,需要设置gzip_types指令。
gzip_types text/plain application/xml;
使用gzip_min_length指令指定响应进行压缩的最小长度。默认是20字节(下面调整为1000字节)。
gzip_min_length 1000;
默认,Nginx不压缩给代理请求的响应(请求来自代理服务器)。请求来自代理服务器是通过请求的Via头字段决定。为了配置这些响应的压缩,使用gzip_proxied指令。指令有大量参数指定Nginx应该压缩那些种类的代理请求。例如,只有请求不缓存在代理服务器压缩响应才是合理的。由于这个目的gzip_proxied指令有参数指示Nginx检查Cache-Control头字段在响应,如果值是no-cache、no-store或private压缩响应。此外,你必须指定expired参数检查Expires头字段。同样适用auth参数检查Authorization头字段:
gzip_proxied no-cache no-store private expired auth;
和大多数其它指令一样,压缩指令能包括在http上下文或server或location配置块。
gzip的总体配置如下所示:
server {
gzip on;
gzip_types text/plain application/xml;
gzip_proxied no-cache no-store private expired auth;
gzip_min_length 1000;
...
}
3 启用解压
有些客户端不支持gzip编码方式响应。同时,它可以存储压缩数据,或压缩动态响应并存储在缓存中。为了成功的服务接收或不接收压缩数据的客户端,Nginx能动态解压数据发送给不能接收压缩数据的客户端。
为了启用运行时解压,使用gunzip指令。
location /storage/ {
gunzip on;
...
}
gunzip指令和gzip指令可以用于相同的上下文:
server {
gzip on;
gzip_min_length 1000;
gunzip on;
...
}
注意,这个指令是一个单独的模块,默认没有包括在开源的Nginx构建中。
4 发送压缩文件
为了发送一个压缩版本的文件给客户端而不是普通的,设置gzip_static指令为on。
location / {
gzip_static on;
}
在这种情况下,服务请求/path/to/file,Nginx尝试找到并发送文件/path/to/file.gz。如果文件不存在,或客户端不支持gzip,Nginx发送未压缩的文件。
注意,gzip_static指令不启用在线压缩。它只是使用压缩工具预先压缩好文件。为了在运行时压缩内容(不仅是静态内容),使用gzip指令。
注意,这个指令是一个单独的模块,默认没有包括在开源的Nginx构建中。