在反向代理模式下使用NGINX压缩资产

时间:2017-10-02 17:56:28

标签: node.js nginx gzip reverse-proxy

我在Node.js应用程序前面使用NGINX作为反向代理。基本代理工作得非常好,我能够使用compression中间件压缩节点服务器上的资产。

为了测试是否可以将压缩任务委托给NGINX,我已经禁用了中间件,现在我正在尝试使用以下配置使用NGINX进行gzip:

worker_processes 1;

events {
    worker_connections 1024;
}

http {
    include mime.types;
    default_type application/octet-stream;
    sendfile on;
    keepalive_timeout 300;
    server {
        listen 80;

        ## gzip config
        gzip on;
        gzip_min_length 1000;
        gzip_comp_level 5;
        gzip_proxied any;
        gzip_vary on;
        gzip_types text/plain
                   text/css
                   text/javascript
                   image/gif
                   image/png
                   image/jpeg
                   image/svg+xml
                   image/x-icon;

        location / {
            proxy_pass http://app:3000/;
            proxy_http_version 1.1;

            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection 'upgrade';
            proxy_cache_bypass $http_upgrade;
            }
    }
}

使用此配置,NGINX不会压缩资产。我尝试在location上下文中使用不同的选项声明这些,但似乎没有一个可以解决这个问题。

我找不到相关的资源,所以我质疑是否可以这样做。

重点:

1-节点和NGINX在不同的容器上,因此我不使用NGINX为静态资产提供服务。我只是代理服务这些文件的节点服务器。我想要实现的只是卸载节点服务器,让NGINX进行gzipping。

2-我正在使用“Accept-Encoding:gzip”启用测试所有响应。

1 个答案:

答案 0 :(得分:1)

尝试添加application/javascript内容类型:

gzip_types
    text/css
    text/javascript
    text/xml
    text/plain
    text/x-component
    application/javascript
    application/json
    application/xml
    application/rss+xml
    font/truetype
    font/opentype
    application/vnd.ms-fontobject
    image/svg+xml;

我从这个conf H5BP中获取了值: