5

我正在尝试使用 NginX 作为一些 IIS 服务器的反向代理。目标是让 NginX 从 IIS / Apache 服务器缓存静态项目,如 CSS / JS / 图像。我还试图让 NginX 使用其 perl 模块自动缩小 js / css 文件。

我在这里找到了一个用于缩小的示例脚本:

http://petermolnar.eu/linux-tech-coding/nginx-perl-minify-css-js/

使用脚本一切正常,除了反向代理中断。

问题:

  1. 我正在努力完成的事情是否可能?我希望 NginX 在将它们保存到缓存之前先缩小脚本。
  2. nginX 可以自动设置正确的过期标头,以便尽可能长时间缓存静态项目,并且仅在更改查询字符串时替换(jquery.js?timestamp=march-2012)
  3. NginX 可以在发送资源之前将其 GZIP。
  4. 如果 NGinx 无法连接到后端服务器,它可以转发请求或提供“停机维护页面”。

任何帮助将不胜感激。

到目前为止,这是我的站点启用/默认值。

    server {


    location / {

        proxy_pass             http://mywebsite.com;
        proxy_set_header       Host $host;
        proxy_cache            STATIC;
        proxy_cache_valid      200  1d;
        proxy_cache_use_stale  error timeout invalid_header updating
                              http_500 http_502 http_503 http_504;
    }


    location @minify {
                    perl Minify::minify_handler;
            }

            location ~ \.css$ {
                    try_files $uri.min.css @minify;
            }




            location /*.js {
                 expires 30d;
            }



}
4

1 回答 1

6

Nginx 是反向代理的理想解决方案,也是 Unix 方式“做一件事,做好”。所以我建议你将内容服务和缩小过程分开,而不是使用第三方插件一次做很多事情。

最佳实践是在进行生产部署之前在本地系统上执行 minify&obfuscate 阶段,这说起来容易做起来也不难,请参阅google压缩静态资产的方式。一旦你准备好使用资产,我们就可以设置 nginx 配置。

答案:

  1. 在将其部署到生产环境之前使用 minify&obfuscate

  2. 您可以通过正则表达式(目录名或文件扩展名)查找资产

    位置 ~ ^/(assets|images|javascripts|stylesheets|swfs|system)/ { gzip_static on; 最大过期;add_header 缓存控制公共;add_header Last-Modified ""; add_header ETag ""; 休息; }

  3. 使用gzip ongzip_static on来提供 gzip 文件,而不是每次请求到来时都压缩它。

  4. 使用try_files检测维护页面是否存在

    try_files $uri /system/maintenance.html @mywebsite;

    if (-f $document_root/system/maintenance.html) { 返回 503; }

请参阅您的案例的完整 nginx 配置:

http {
  keepalive_timeout         70;

  gzip                      on;
  gzip_http_version         1.1;
  gzip_disable              "msie6";
  gzip_vary                 on;
  gzip_min_length           1100;
  gzip_buffers              64 8k;
  gzip_comp_level           3;
  gzip_proxied              any;
  gzip_types                text/plain text/css application/x-javascript text/xml application/xml;

  upstream mywebsite {
    server                  192.168.0.1 # change it with your setting
  }

  server {
    try_files               $uri /system/maintenance.html @mywebsite;

    location @mywebsite {
      proxy_set_header      X-Forwarded-For $proxy_add_x_forwarded_for;
      proxy_set_header      X-Forwarded-Proto $scheme;
      proxy_set_header      Host $http_host;
      proxy_redirect        off;
      proxy_pass            http://mywebsite;
    }

    location ~ ^/(assets|images|javascripts|stylesheets|swfs|system)/ {
      gzip_static       on;
      expires           max;
      add_header        Cache-Control public;
      add_header        Last-Modified "";
      add_header        ETag "";
      break;
    }

    if (-f $document_root/system/maintenance.html) {
      return            503;
    }

    location @503 {
      error_page 405 = /system/maintenance.html;
      if (-f $document_root/system/maintenance.html) {
        rewrite         ^(.*)$ /system/maintenance.html break;
      }
      rewrite           ^(.*)$ /503.html break;
    }

  }

}
于 2012-07-14T11:52:42.673 回答