Rails 4 升级生产 nginx 问题



>我最近将我们的应用程序从 3 更新到 4.2.7,现在我们在生产环境中遇到了问题:

  1. 资产以文本/html 的形式提供,而不是它们各自的 css/js 标头。
  2. (可能相关)找不到子目录中的预编译资产,这意味着/cssfile.css已成功加载,而/subdir/cssfile.css则未成功加载。

在升级过程中,nginx配置文件没有变化。config/environment/production.rb 中的更改如下:

+ config.eager_load = true
-  config.serve_static_assets = false
+  config.serve_static_files = false
-  config.assets.compress = true
+  config.assets.js_compressor  = :uglifier
+  config.assets.css_compressor = :sass

在部署时,config.assets.css_compressor = :sass导致了问题,所以我删除了它并成功完成了预编译,不知道为什么会发生这种情况,因为我在某处读到在 Rails 4 中默认css_compressor是 :sass。

这是网站上使用的nginx配置:

upstream SITENAME {
  server unix:/home/deploy/SITENAME/shared/pids/unicorn.sock;
}
server {
  listen 80;
  server_name production.SITENAMEart.com;
  root /home/deploy/SITENAME/current/public;
  access_log  /var/log/nginx/SITENAME.access.log  main;
  client_max_body_size 64M;
  location ~ ^/assets/ {
    expires max;
    add_header Cache-Control public;
    add_header ETag "";
    break;
  }
  location ~ ^/(assets)/ {
    root /home/deploy/SITENAME/current/public;
    gzip_static on;
    expires max;
    add_header Cache-Control public;
  }
  location / {
    try_files $uri @SITENAME;
  }
  location @SITENAME {
    include proxy.conf;
    proxy_pass http://SITENAME;
  }
  # stats url
  location /nginx_stats {
    stub_status on;
    access_log   off;
    #allow SOME.IP.ADD.RESS;
    #deny all;
  }
}
server {
  listen 443;
  server_name production.SITENAMEart.com;
  root /home/deploy/SITENAME/current/public;
  access_log  /var/log/nginx/SITENAME.access.log  main;
  ssl on;
  ssl_certificate         /usr/local/nginx/conf/ssl/wildcard.SITENAMEart.com.crt;
  ssl_certificate_key     /usr/local/nginx/conf/ssl/wildcard.SITENAMEart.com.key.unsecure;
  ssl_client_certificate  /usr/local/nginx/conf/ssl/geotrust.crt;
  location ~ ^/assets/ {
    expires max;
    add_header Cache-Control public;
    add_header ETag "";
    break;
  }
  location / {
    try_files $uri @SITENAME;
    proxy_set_header   X-Forwarded-Proto https;
  }
  location @SITENAME {
    include proxy.conf;
    proxy_pass http://SITENAME;
    proxy_set_header   X-Forwarded-Proto https;
  }
  # stats url
  location /nginx_stats {
    stub_status on;
    access_log   off;
  }
}

最让我惊讶的是,该版本在部署到生产环境之前在暂存中进行了彻底的测试,并且它具有nginx配置 - 那里没有出现任何问题。

问题已解决。它与我从 Capistrano v2 移植的自定义符号链接脚本有关,该脚本在生成资产后删除了公共/资产目录的内容。

不过,我还没有找出为什么这不是我们的登台服务器上的问题。

最新更新