ruby-on-rails-4 - `Errno::EExist` 在开发中运行导轨时 sprockets 出错

标签 ruby-on-rails-4 asset-pipeline assets sprockets

我现在已经多次发生这种情况,我希望有人可以对以下错误提供一些见解:

Errno::EEXIST at / File exists @ dir_s_mkdir - tmp/cache/assets/sprockets/v3.0/Pd

这是相关的堆栈跟踪:

Errno::EEXIST - File exists @ dir_s_mkdir - /home/dev/keithgw-dev/code/myapp/tmp/cache/assets/sprockets/v3.0/Pd:
() opt/rubies/ruby-2.2.2/lib64/ruby/2.2.0/fileutils.rb:252:in `fu_mkdir'
() opt/rubies/ruby-2.2.2/lib64/ruby/2.2.0/fileutils.rb:226:in `block (2 levels) in mkdir_p'
() opt/rubies/ruby-2.2.2/lib64/ruby/2.2.0/fileutils.rb:224:in `block in mkdir_p'
() opt/rubies/ruby-2.2.2/lib64/ruby/2.2.0/fileutils.rb:210:in `mkdir_p'
sprockets (3.6.0) lib/sprockets/cache/file_store.rb:85:in `set'
sprockets (3.6.0) lib/sprockets/cache.rb:212:in `set'
sprockets (3.6.0) lib/sprockets/cache.rb:136:in `set'
sprockets (3.6.0) lib/sprockets/loader.rb:321:in `fetch_asset_from_dependency_cache'
sprockets (3.6.0) lib/sprockets/loader.rb:44:in `load'
sprockets (3.6.0) lib/sprockets/cached_environment.rb:20:in `block in initialize'
sprockets (3.6.0) lib/sprockets/cached_environment.rb:47:in `load'
sprockets (3.6.0) lib/sprockets/base.rb:66:in `find_asset'
sprockets (3.6.0) lib/sprockets/base.rb:73:in `find_all_linked_assets'
sprockets (3.6.0) lib/sprockets/manifest.rb:142:in `block in find'
sprockets (3.6.0) lib/sprockets/legacy.rb:114:in `block (2 levels) in logical_paths'
sprockets (3.6.0) lib/sprockets/path_utils.rb:223:in `block in stat_tree'
sprockets (3.6.0) lib/sprockets/path_utils.rb:207:in `block in stat_directory'
sprockets (3.6.0) lib/sprockets/path_utils.rb:204:in `stat_directory'
sprockets (3.6.0) lib/sprockets/path_utils.rb:222:in `stat_tree'
sprockets (3.6.0) lib/sprockets/legacy.rb:105:in `block in logical_paths'
sprockets (3.6.0) lib/sprockets/legacy.rb:104:in `logical_paths'
sprockets (3.6.0) lib/sprockets/manifest.rb:140:in `find'
sprockets-rails (3.0.4) lib/sprockets/railtie.rb:49:in `precompiled_assets'
sprockets-rails (3.0.4) lib/sprockets/railtie.rb:34:in `asset_precompiled?'
sprockets-rails (3.0.4) lib/sprockets/railtie.rb:214:in `block (3 levels) in <class:Railtie>'
sprockets-rails (3.0.4) lib/sprockets/rails/helper.rb:345:in `precompiled?'
sprockets-rails (3.0.4) lib/sprockets/rails/helper.rb:349:in `raise_unless_precompiled_asset'
sprockets-rails (3.0.4) lib/sprockets/rails/helper.rb:334:in `find_debug_asset'
sprockets-rails (3.0.4) lib/sprockets/rails/helper.rb:216:in `block in lookup_debug_asset'
sprockets-rails (3.0.4) lib/sprockets/rails/helper.rb:229:in `block in resolve_asset'
sprockets-rails (3.0.4) lib/sprockets/rails/helper.rb:228:in `resolve_asset'
sprockets-rails (3.0.4) lib/sprockets/rails/helper.rb:215:in `lookup_debug_asset'
sprockets-rails (3.0.4) lib/sprockets/rails/helper.rb:157:in `block in stylesheet_link_tag'
sprockets-rails (3.0.4) lib/sprockets/rails/helper.rb:156:in `stylesheet_link_tag'
() home/dev/keithgw-dev/code/myapp/app/views/layouts/application.html.erb:8:in `_app_views_layouts_application_html_erb__3086746537636264556_24830040'

它似乎无法在 tmp/cache 中创建一个随机子目录以缓存动态编译的 Assets (我在 development 模式下运行)。但是,错误消息中显示的目录确实存在。

清除临时缓存并重新启动 rails 并不能解决问题。我能够解决这个问题的唯一方法是在其他地方的同一系统上启动另一个 Rails 应用程序。在那之后,我杀死它并重新启动失败的应用程序,它再次工作。没有真正的证据表明这是一个实际的工作,或者这只是一个巧合。

无论如何,我很想听听其他曾经经历过这种情况的人的意见,或者是否有人能够解释为什么会发生这种情况。

谢谢。

  • Rails - 4.2.6
  • Ruby - 2.2.2

最佳答案

显然我的 Google-fu 今天很强大。我发现了一张针对 Sprockets 3.6.0 的票证,该票证与不区分大小写的文件系统有关。见 https://github.com/rails/sprockets/issues/283

(这是我的情况,无论如何,在 Windows 主机上运行 vagrant)

很遗憾,项目的维护者似乎仍在讨论修复。

关于ruby-on-rails-4 - `Errno::EExist` 在开发中运行导轨时 sprockets 出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38252396/

相关文章:

ruby-on-rails - 为什么 Image_tag 产生 "images/..."而不是 "assets/...."?

php - Yii2组合和压缩 Assets 不适用于 bundle

ruby-on-rails - 无方法错误 : undefined method `find' for nil:NilClass

postgresql - 导轨 4 : Advanced Query for Search Interface

jquery - 使用 asset pipeline 和 pjax 时未捕获的 ReferenceError

ruby-on-rails - Assets 管道 Rails 4 看不到带有 md5 指纹的文件

git - 应该如何处理与 Git 存储库相关的媒体 Assets ?

ruby-on-rails - 从 Controller 渲染 js 时使用 Rails Sprockets 指令

ruby-on-rails - 混合使用 ERB 和 Rails 路径助手编译 YAML

ruby-on-rails - rails 4.1 将视频文件夹添加到 Assets 管道