Rails 3.1.0.rc4でassetsが全部404 not foundになる

Rails 3.1.0.rc4で新しいプロジェクトを作ったところ、すべてのassetが404 not foundになる現象に見舞われました。

まず、通常通りRailsアプリを作って起動します。

[bash]
rails new myapp
cd myapp
vi Gemfile #gem ‘execjs’, gem ‘therubyracer’ を追記
bundle install
rails s
[/bash]

3.1ではCofeeScriptを使うため、execjsとtherubyracerをGemfileに追記しておく必要があります。
※aptのlibv8-devが入っている環境ではなぜかエラーになったので、removeしたらうまくgemが入りました。

さて、これで http://localhost:3000/assets/rails.png にアクセスすれば、railsのロゴがでるはずなのですが、

Routing Error
No route matches [GET] “/assets/rails.png”

となってしまいます。

ログを見ると、

Started GET “/assets/rails.png” for 127.0.0.1 at 2011-08-12 12:08:02 +0900
Served asset /rails.png – 404 Not Found (9ms) (pid 3897)

ActionController::RoutingError (No route matches [GET] “/assets/rails.png”):

です。
assetを読もうとはしているのですが、失敗しているようです。app/assets/images/rails.pngはちゃんと存在します。

この現象は、assetを出力するsprocketsのバージョンが2.0.0.beta.10以下の場合は発生しないのですが、2.0.0.beta.11以上の場合に発生するようです。

この現象が発生した場合の解決策は簡単、Rails 3.1.0.rc5にアップデートすることです。

[bash]
rm Gemfile.lock
vi Gemfile #gem ‘rails’, ‘3.1.0.rc5’
bundle install
[/bash]

まだRCなので仕方ないですね。

参考
http://comments.gmane.org/gmane.comp.lang.ruby.rails.core/15704

Ruby on RailsによるWEBシステム開発、Android/iPhoneアプリ開発、電子書籍配信のことならお任せください この記事を書いた人と働こう! Ruby on Rails の開発なら実績豊富なBPS

この記事の著者

baba

ゆとりプログラマー。 高校時代から趣味でプログラミングを初め、そのままコードを書き続けて現在に至る。慶應義塾大学環境情報学部(SFC)卒業。BPS設立初期に在学中から参加している最古参メンバーの一人。得意分野はWeb全般、Ruby on Rails、Androidアプリケーションなど。最近はBlinkと格闘中。軽度の資格マニアで、情報処理技術者試験(高度10区分)などを保有。

babaの書いた記事

週刊Railsウォッチ

インフラ

Rubyスタイルガイドを読む

BigBinary記事より

ActiveSupport探訪シリーズ