posts - 262,  comments - 221,  trackbacks - 0

          今天使用Rails3.0.7 + rake 0.9.2部署Rails應用到heroku時,發現在heroku上面無法執行rake db:migrate命令。報錯信息如下:

          paul@RoR:~/Workspace/rails_projects/demo_app$ heroku rake db:migrate
          (
          in /app)
          rake aborted
          !
          uninitialized constant Rake::DSL
          /usr/ruby1.9.2/lib/ruby/1.9.1/rake.rb:2482:in `const_missing'
          /app/.bundle/gems/ruby/1.9.1/gems/rake-0.9.2/lib/rake/tasklib.rb:8:in `<class:TaskLib>'

          看來是rake的問題了,于是查了一下rake的版本

          paul@RoR:~/Workspace/rails_projects/demo_app$ bundle 
          Using rake (
          0.9.2
          Using 
          abstract (1.0.0
          Using activesupport (
          3.0.7
          Using builder (
          2.1.2
          Using i18n (
          0.5.0
          Using activemodel (
          3.0.7)

          網上google了一下,發覺又是一個Rails和其他gem不兼容的問題,只要把rake的版本設置為0.8.7就可以了。

          Rails3.0的Gem配置在文件Gemfile中設置,但是默認的不會有rake的版本指定,我們需要手工指定。修改Gemfile,增加對rake的版本指定

          gem 'rails''3.0.7'
          gem 
          'rake''0.8.7'

          這樣在沒有rake0.8.7這個版本時,bundle會自動去RubyForge.org下載,如果本地已經安裝了則使用本地的gem

          滿以為這樣就可以了,可是一執行bundle install還是報錯

          paul@RoR:~/Workspace/rails_projects/demo_app$ bundle install
          Fetching source index 
          for http://rubygems.org/
          You have requested:
            rake 
          = 0.8.7

          The bundle currently has rake locked at 
          0.9.2.
          Try running `bundle update rake`
          paul@RoR:
          ~/Workspace/rails_projects/demo_app$ bundle unlock
          Unlock 
          is deprecated. To update to newer gem versions, use `bundle update`.
          paul@RoR:
          ~/Workspace/rails_projects/demo_app$ bundle update rake

          這是為什么呢?怎么會說bundle被鎖定呢?原來啊Rails為了保證應用在不同的環境下配置一樣,會對Gemfile生成一個lock文件,該lock文件把當前應用的gem配置都記錄下來,并一同發布出去(這里指的是GitHub),一旦其他人下載該應用后執行bundle install時會強制按照該lock文件中指定的gem版本去下載或調用,而不是使用其他人本地已經安裝的gem,這樣就可以保證在不同的環境下應用的特性一致。

          在完成對bundle的解鎖后,依次執行下列命令
          git commit -a
          git push origin master
          git push heroku master

          完成之后,再次執行heroku rake db:migrate,問題解決
          paul@RoR:~/Workspace/rails_projects/demo_app$ heroku rake db:migrate
          (
          in /app)
          Migrating to CreateUsers (
          20110628080358)
          ==  CreateUsers: migrating ====================================================
          -- create_table(:users)
             
          -> 0.0095s
          ==  CreateUsers: migrated (0.0096s) ===========================================

          Migrating to CreateMicroposts (
          20110629094445)
          ==  CreateMicroposts: migrating ===============================================
          -- create_table(:microposts)
             
          -> 0.0059s
          ==  CreateMicroposts: migrated (0.0060s) ======================================



          -------------------------------------------------------------
          生活就像打牌,不是要抓一手好牌,而是要盡力打好一手爛牌。
          posted on 2011-07-03 21:28 Paul Lin 閱讀(1424) 評論(1)  編輯  收藏


          FeedBack:
          # re: heroku rake db:migrate 錯誤解決一則[未登錄]
          2011-08-14 00:55 | rex
          問題解決 謝謝  回復  更多評論
            

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          <2011年7月>
          262728293012
          3456789
          10111213141516
          17181920212223
          24252627282930
          31123456

          常用鏈接

          留言簿(21)

          隨筆分類

          隨筆檔案

          BlogJava熱點博客

          好友博客

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 九台市| 弋阳县| 黄山市| 化德县| 蒙阴县| 应城市| 思茅市| 班戈县| 丁青县| 平湖市| 山阴县| 会宁县| 北海市| 虎林市| 永寿县| 汝南县| 出国| 化州市| 尼木县| 根河市| 光泽县| 晴隆县| 乌拉特前旗| 安化县| 丘北县| 东丽区| 辽宁省| 吴江市| 交口县| 镇赉县| 武安市| 富平县| 安龙县| 义马市| 黄石市| 新河县| 兴义市| 宣城市| 闻喜县| 平安县| 阳信县|