>我最近将我们的应用程序从 3 更新到 4.2.7,现在我们在生产环境中遇到了问题:
- 资产以文本/html 的形式提供,而不是它们各自的 css/js 标头。
- (可能相关)找不到子目录中的预编译资产,这意味着
/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 移植的自定义符号链接脚本有关,该脚本在生成资产后删除了公共/资产目录的内容。
不过,我还没有找出为什么这不是我们的登台服务器上的问题。