0

我正在使用 nginx 从 nodejs 服务器 gzip 静态文件和 json 响应。

对于一个特定的请求(带有类似的查询字符串"?fn=foo"),我需要发送一个非 gzip json 响应。

我尝试使用 nginx 位置模块来实现这一点,基于查询字符串上的正则表达式,但查询字符串不在用于匹配 nginx 位置的 URI 中我试图if ($arg_fn = "foo") {gzip off;}在我的主要位置路由中放置一个,但是它以 404 失败。

任何想法?是否可以使用 nginx 实现这一点?或者有没有办法告诉从 nodejs 到 nginx 不要 gzip 这个响应?

我的 nginx 配置文件:

worker_processes  1;

error_log  /var/log/nginx/error.log;
pid        /var/run/nginx.pid;
events {
    worker_connections  1024;
}

http {
    proxy_cache_path  /var/cache/nginx levels=1:2 keys_zone=one:8m max_size=3000m inactive=600m;
    proxy_temp_path /var/cache/nginx/proxy_temp;

    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;
    sendfile        on;
    keepalive_timeout  65;

    gzip  on;
    gzip_comp_level 6;
    gzip_vary on;
    gzip_min_length  1000;
    gzip_proxied any;
    gzip_types text/plain text/css application/x-javascript text/xml application/xml application/xml+rss text/javascript application/javascript application/json;
    gzip_buffers 16 8k;

    map $http_upgrade $connection_upgrade {
        default upgrade;
        ''      close;
    }

    upstream upstream {
      server 127.0.0.1:8887;
      server 127.0.0.1:8888;
      keepalive 64;
    }

    server {
        listen       80;
        listen       443 ssl;
        server_name  _;

        ssl_certificate /etc/nginx/ssl/zellno-ssl-bundle.crt;
        ssl_certificate_key /etc/nginx/ssl/zellno-key.pem;


        location / {
            if ($arg_fn = "comp") {
                gzip off;
            }

            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-NginX-Proxy true;
            proxy_set_header X-Forwarded-Proto $scheme;

            proxy_pass http://upstream/;
            proxy_redirect off;
            proxy_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection $connection_upgrade;
            proxy_set_header Host $host;
        }

        error_page  404              /404.html;
        location = /40x.html {
            root   /usr/share/nginx/html;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   /usr/share/nginx/html;
        }
    }
}
4

1 回答 1

0

我认为您的问题是您$args_fn用“s”说,虽然它应该是$arg_fn单数形式,但请尝试并告诉我它是如何进行的。

编辑:试试这个以确保你输入 if 块

location / {
    if ($arg_fn = "comp") {
        return 444;
        #gzip off;
    }
}

如果它返回错误代码,那么它if正在工作,但不是 gzip,如果它不起作用,那么我们需要修复第if一个

于 2013-11-06T11:36:56.020 回答