0

私はnginxを使用して、nodejsサーバーからの静的ファイルとjson応答をgzipしています。

1 つの特定の要求 (のようなクエリ文字列を使用"?fn=foo") に対して、非 gzip json 応答を送信する必要があります。

クエリ文字列の正規表現に基づいて、nginx ロケーション モジュールでこれを達成しようとしましたが、クエリ文字列は、nginx によって場所を照合するために使用される URI にありませんif ($arg_fn = "foo") {gzip off;}。代わりに 404 で失敗します。

何か案が?nginxでこれを達成することは可能ですか? または、この応答をgzipしないようにnodejsからnginxに伝える方法はありますか?

私のnginx confファイル:

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;
    }
}

エラー コードが返された場合、gzip は機能していますifが、gzip は機能していません。機能しない場合は、if最初の部分を修正する必要があります。

于 2013-11-06T11:36:56.020 に答える