正如标题所说,Nginx Gzip 不起作用,我尝试了互联网上散布的许多配置,但都没有起作用,当简单的东西不起作用时我真的很沮丧。
gzip.conf:
gzip on;
gzip_disable "msie6";
gzip_vary on;
gzip_proxied any;
gzip_comp_level 6;
gzip_buffers 16 8k;
gzip_http_version 1.1;
gzip_min_length 256;
gzip_types
text/plain
text/css
application/json
application/javascript
application/x-javascript
text/xml
application/xml
application/xml+rss
text/javascript
application/vnd.ms-fontobject
application/x-font-ttf
font/opentype
image/svg+xml
image/x-icon;
Chrome:
我已清除缓存,但一切仍然一样。
=======================
更新:
我已经测试过 gzip 压缩
http://checkgzipcompression.com/
并给了我:
但Chrome
其中显示:
Firefox:
removed gzip_vary
* Hostname was NOT found in DNS cache
* Trying 192.168.200.240...
* Connected to 192.168.200.240 (192.168.200.240) port 80 (#0)
> HEAD /js/main.js HTTP/1.1
> User-Agent: curl/7.35.0
> Host: 192.168.200.240
> Accept: */*
> Accept-Encoding: deflate, gzip
>
< HTTP/1.1 200 OK
HTTP/1.1 200 OK
< Date: Sat, 03 Dec 2016 16:25:34 GMT
Date: Sat, 03 Dec 2016 16:25:34 GMT
< Content-Type: application/javascript
Content-Type: application/javascript
< Last-Modified: Fri, 02 Dec 2016 03:20:46 GMT
Last-Modified: Fri, 02 Dec 2016 03:20:46 GMT
< Connection: keep-alive
Connection: keep-alive
< ETag: W/"5840e88e-18ce"
ETag: W/"5840e88e-18ce"
* Server nginx is not blacklisted
< Server: nginx
Server: nginx
< Expires: Sun, 03 Dec 2017 16:25:34 GMT
Expires: Sun, 03 Dec 2017 16:25:34 GMT
< Cache-Control: max-age=31536000
Cache-Control: max-age=31536000
< Content-Encoding: gzip
Content-Encoding: gzip
<
* Connection #0 to host 192.168.200.240 left intact
nginx -V
nginx version: nginx/1.10.1
built with OpenSSL 1.0.1f 6 Jan 2014
TLS SNI support enabled
configure arguments: --with-cc-opt='-g -O2 -fstack-protector --param=ssp-buffer-size=4 -Wformat -Werror=format-security -D_FORTIFY_SOURCE=2' --with-ld-opt='-Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,-z,now' --prefix=/usr/share/nginx --conf-path=/etc/nginx/nginx.conf --http-log-path=/var/log/nginx/access.log --error-log-path=/var/log/nginx/error.log --lock-path=/var/lock/nginx.lock --pid-path=/run/nginx.pid --modules-path=/usr/lib/nginx/modules --http-client-body-temp-path=/var/lib/nginx/body --http-fastcgi-temp-path=/var/lib/nginx/fastcgi --http-proxy-temp-path=/var/lib/nginx/proxy --http-scgi-temp-path=/var/lib/nginx/scgi --http-uwsgi-temp-path=/var/lib/nginx/uwsgi --with-debug --with-pcre-jit --with-ipv6 --with-http_ssl_module --with-http_stub_status_module --with-http_realip_module --with-http_auth_request_module --with-http_v2_module --with-http_dav_module --with-http_slice_module --with-threads --with-http_addition_module --with-http_flv_module --with-http_geoip_module=dynamic --with-http_gunzip_module --with-http_gzip_static_module --with-http_image_filter_module=dynamic --with-http_mp4_module --with-http_perl_module=dynamic --with-http_random_index_module --with-http_secure_link_module --with-http_sub_module --with-http_xslt_module=dynamic --with-mail=dynamic --with-mail_ssl_module --with-stream=dynamic --with-stream_ssl_module --add-dynamic-module=/build/nginx-JCHwcf/nginx-1.10.1/debian/modules/headers-more-nginx-module --add-dynamic-module=/build/nginx-JCHwcf/nginx-1.10.1/debian/modules/nginx-auth-pam --add-dynamic-module=/build/nginx-JCHwcf/nginx-1.10.1/debian/modules/nginx-cache-purge --add-module=/build/nginx-JCHwcf/nginx-1.10.1/debian/modules/nginx-dav-ext-module --add-dynamic-module=/build/nginx-JCHwcf/nginx-1.10.1/debian/modules/nginx-development-kit --add-dynamic-module=/build/nginx-JCHwcf/nginx-1.10.1/debian/modules/nginx-echo --add-dynamic-module=/build/nginx-JCHwcf/nginx-1.10.1/debian/modules/ngx-fancyindex --add-dynamic-module=/build/nginx-JCHwcf/nginx-1.10.1/debian/modules/nchan --add-dynamic-module=/build/nginx-JCHwcf/nginx-1.10.1/debian/modules/nginx-lua --add-dynamic-module=/build/nginx-JCHwcf/nginx-1.10.1/debian/modules/nginx-upload-progress --add-dynamic-module=/build/nginx-JCHwcf/nginx-1.10.1/debian/modules/nginx-upstream-fair --add-dynamic-module=/build/nginx-JCHwcf/nginx-1.10.1/debian/modules/ngx_http_substitutions_filter_module
答案1
看起来您的服务器已启用 gzip(查看 curl 响应和 checkgzipcompression 结果)。但由于您使用了指令,因此gzip_vary on;
您会获得Vary: Accept-Encoding
标头。
所以基本上服务器允许客户端决定 https://www.maxcdn.com/blog/accept-encoding-its-vary-important/
使用什么编码。如果它已经有未压缩的文件,它将不会获得 gzip 压缩的文件(对我来说这似乎也很奇怪,但这就是知识渊博的文章所述的)。
我知道这与您看到的“硬刷新缓存清理页面”不一致。但这是一个线索,请尝试将其关闭,重新启动 nginx 并再次检查(当然还要验证 gzip.conf 是否确实被 nginx 读取和使用)
答案2
这一直是我的防病毒软件,与此帖子存在类似的问题: nginx gzip 已启用但未启用 gzipping
我认为这不是因为我在测试时暂时禁用了防病毒软件,但我认为即使禁用了防病毒软件,防病毒软件也会解压缩它。
而且,即使我打开了防病毒软件,我检查过的其他网站也很gzipped
奇怪,所以我认为这不是我的防病毒软件的问题。
但是我已经在仅安装了 chrome 的新 VM 中对其进行了测试,并且它gzip
也通过远程调试显示在我的移动设备上。
然后我在虚拟机上安装了防病毒软件,然后它就Content-Encoding: gzip
消失了。
我也检查过wireshark
内容是否属实gzipped
。但不知为何,杀毒软件却解压了它。
我的工作区和虚拟机中的 chrome 版本是相同的。
Chrome Version 54.0.2840.99
答案3
我知道这个问题已经很久没有得到解答了。是的。是防病毒软件在传输之前解压了内容。为了诱使防病毒软件保留 GZIP 内容,我向 nginx 添加了相同的 Content-Encoding 标头,但略作了改动。
开启 gzip; 添加标头内容编码“gzip2”;
这样,我就不必停止在后台运行的防病毒软件了。我希望这能帮助那些遇到同样问题的人。一切都始于 IIS 不压缩内容,这促使我添加了 NginX,但它也不压缩内容。这完全是防病毒软件的问题!