Rails 4 应用程序 - Heroku / Cloudfront - 资产无法从源正确服务



我有一个 rails 4 应用程序,其中我们使用 cloudfront 作为 CDN。

production.rb文件中,我们有以下代码:

config.action_controller.asset_host = "example3579.cloudfront.net"

我们已经做了一些非常彻底的资产分离。从资产管道的角度来看,这可能不可取,但它应该使调试此问题变得非常容易。

我正在处理的特定页面是users#edit视图,但问题是普遍的。

users#edit操作使用自己的布局:views/layouts/user_edit.html.erb

views/layouts/user_edit.html.erb文件调用此 javascript。

<%= javascript_include_tag 'user_edit'%>

assets/javascripts/user_edit.js

//= require jquery
//= require jquery_ujs
//= require jquery.validate.min
//= require ./webarch/form_validations

在本地主机上,这有效。我可以像这样在浏览器中访问 js:

http://localhost:3000/assets/user_edit.js

但是在使用 heroku 的生产中,该网站会查找此文件:

<script src="http://example3579.cloudfront.net/javascripts/user_edit.js"></script>

该文件不起作用。我无法在浏览器中访问,并且 javascript 无法在页面上呈现。我已经预编译了资产。

添加gem 'rails_12factor', group: :production # 对 Rails 有帮助 4 个 heroku 资产

在/config/environment/production.rb 中

config.assets.compile = true

这应该有效