我有一个 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
这应该有效