ruby-on-rails-3 – Manifest.yml没有使用资源进行更新:precomp
我试图确保我使用Rails资产管道提供压缩的css和js文件.我已经很好地设置了这一切,事情正在快速预编译,并且还快速地同步到S3,在那里我使用Amazon的CloudFront CDN为他们提供服务.
我正在为application.css和application.js提供服务: = stylesheet_link_tag "application" = javascript_include_tag "application" 这个问题简单地说:MD5后缀文件没有在应用程序布局中输出 – 只有原始的application.css和application.js 这有点陌生:所有的图像都有一个MD5邮票. CSS / JS文件没有. 这是我的production.config: config.action_controller.perform_caching = true # Specifies the header that your server uses for sending files config.action_dispatch.x_sendfile_header = "X-Sendfile" config.assets.compress = true # Fallback to compile on demand # config.assets.compile = true #config.assets.precompile += %w(application.css application.js) # Generate digests for assets URLs config.assets.digest = true #push the assets to amazon config.action_controller.asset_host = Proc.new { |source,request| if request.ssl? "https://tekpub-assets.s3.amazonaws.com" else "http://tekpub-assets.s3.amazonaws.com" end } config.serve_static_assets = false 关于这个整个过程的令人讨厌的事情是,我可以看到gzip /消化的文件 – 他们就在我的资产目录中.所有的em – CSS和JS文件以及. 但是,我的manifest.yml文件只能像这样更新: --- application.js: application.js application.css: application.css 当我运行预编译时,没有错误 – 其实一切看起来都比较peachy: ** Invoke assets:precompile:all (first_time) ** Execute assets:precompile:all ** Invoke assets:precompile:primary (first_time) ** Invoke assets:environment (first_time) ** Execute assets:environment ** Invoke environment (first_time) ** Execute environment Resolved collector.newrelic.com to 204.93.223.153 AssetSync: using /Volumes/Fatty/Sites/tpub6/config/initializers/asset_sync.rb ** Invoke tmp:cache:clear (first_time) ** Execute tmp:cache:clear ** Execute assets:precompile:primary ** Invoke assets:precompile:nondigest (first_time) ** Invoke assets:environment (first_time) ** Execute assets:environment ** Invoke environment (first_time) ** Execute environment Resolved collector.newrelic.com to 204.93.223.153 AssetSync: using /Volumes/Fatty/Sites/tpub6/config/initializers/asset_sync.rb ** Invoke tmp:cache:clear (first_time) ** Execute tmp:cache:clear ** Execute assets:precompile:nondigest AssetSync: Syncing. Using: Directory Search of /Volumes/Fatty/Sites/tpub6/public/assets AssetSync: Done. 感谢任何指针/推/提示. 解决方法
好的,我找到答案:如果资产管道无法编译文件(或文件类型),它将以Ruby / Rails样式静默失败.
在我的情况下,有两个问题:有一个“.”在一个js文件名(bootstrap.min.js) – 它不喜欢,我认为这是有意义的,因为它使用文件名来找出如何处理文件(例如file.css.erb). 下一个是不知道该怎么做的文件类型.由于移动文件的一些失明和愚蠢,我的资产/图像目录中有一个流行的YAML文件.这阻碍了处理器制作资产:预编译失败…再次默默地. 我发现这个方法是创建一个空的Rails项目,并从头开始编译资产.这就是我发现JS文件问题以及愚蠢的YAML文件. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |