ruby-on-rails – 由独角兽提供服务的Rails为预编译资产生成错误的指纹

我有一个Nginx的生产服务器 – >独角兽 – >轨道.我预编译资产,将资产放在公共/资产中,并在文件名后附加指纹(哈希).但是,当请求网页时,对application.css和application.js资产的引用将具有错误的指纹.例如,rails helper stylesheet_link_tag将生成服务器上public / assets中不存在的文件名,因为请求的指纹与预编译的指纹不匹配.图像资产工作正常(指纹匹配).

对此进行故障排除,我在本地计算机上预编译了资产,指纹与我服务器上的预编译指纹相匹配.此外,当在生产模式下使用webrick在本地运行时,一切正常.然后我尝试在我的服务器上运行webrick,这有效,让我觉得独角兽是问题的根源.

我通过使用–no-default-middleware(或-N)选项启动unicorn解决了这个问题,这使得独角兽的行为与预编译资产相同.我的理解是,这告诉独角兽不要加载一个认的Rack中间件集,否则它会加载.但是,我真的不明白为什么这会解决问题,或者首先出现问题.到底是怎么回事?

一些细节:Ubuntu 12.04,Rails 4.0.1,Ruby 2.1.0,带有第三方主题的bootstrap 3.0

更新:

我不相信这是一个Nginx问题的原因是,当我从浏览器请求页面,然后查看源代码时,application.css文件文件名有指纹,所以它实际上看起来像application-3855b1928b94aa5bff5e1dac1aa56882. CSS.这与我服务器上文件的真实指纹不匹配.我确信服务器上的指纹是正确的,因为我在本地开发机器上获得了相同的指纹.所以客户端正在加载网页,然后向服务器询问.css文件Nginx接收到该请求,但找不到.css文件,因为它实际上不存在,所以Nginx的行为符合预期.

指纹生成两次:一旦我预编译资产,这是正常工作(非常肯定),并且正在发生没有独角兽参与.第二次,当一个独角兽工作者的上下文中的rails看到stylesheet_link_tag帮助器并且即时计算指纹(我认为这就是它正在做的事情),这由于某种原因产生了错误的指纹.如果我在完全相同的服务器上用webrick替换unicorn会发生同样的过程,但在这种情况下指纹匹配.如果我用-N旗开始独角兽,指纹匹配,但我不知道为什么这会产生影响,我不知道为什么其他人似乎不必这样做.

解决方法

在rails 4中,您需要进行以下更改
config.assets.compile = true
config.assets.precompile =  ['*.js','*.css','*.css.erb']

这适用于我.使用以下命令预编译资产

RAILS_ENV=production bundle exec rake assets:precompile

https://stackoverflow.com/questions/18700219/rails-4-assets-not-loading-in-production

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...