使用rake调用heroku toolbelt CLI时,为什么要获得RubyVersionMismatch?

Joe*_*Leo 3 ruby-on-rails heroku rvm heroku-toolbelt

我正在尝试heroku从rake任务执行CLI:

  1 task :call_heroku do     
  2   `heroku pgbackups:url --remote staging`
  3 end    
Run Code Online (Sandbox Code Playgroud)

bundle exec rake call_heroku 返回以下输出:

        /home/joe/.rvm/gems/ruby-2.1.0@global/gems/bundler-1.6.1/lib/bundler/
definition.rb:390:in `validate_ruby!': Your Ruby version is 1.9.3,but your 
Gemfile specified 2.1.0 (Bundler::RubyVersionMismatch)
            from /home/joe/.rvm/gems/ruby-2.1.0@global/gems/bundler-1.6.1/lib/
bundler.rb:116:in `setup'
            from /home/joe/.rvm/gems/ruby-2.1.0@global/gems/bundler-1.6.1/lib/
bundler/setup.rb:17:in `<top (required)>'
            from /usr/lib/ruby/1.9.1/rubygems/custom_require.rb:36:in `require'
            from /usr/lib/ruby/1.9.1/rubygems/custom_require.rb:36:in `require'
        --remote staging
Run Code Online (Sandbox Code Playgroud)

heroku pgbackups:url --remote staging从命令行执行返回预期的URL.我的rvm或heroku CLI配置有问题吗?

环境细节:

Rails 3.2.17

Heroku的:

joe@warpaint ~/dev/project (master) $ heroku version
heroku-toolbelt/2.39.0 (i686-linux) ruby/1.9.3
Run Code Online (Sandbox Code Playgroud)

RVM:

joe@warpaint ~/dev/project (master) $ rvm version

rvm 1.25.22 (stable) by Wayne E. Seguin <wayneeseguin@gmail.com>, Michal Papis <mpapis@gmail.com> [https://rvm.io/]


joe@warpaint ~/dev/project (master) $ rvm list

rvm rubies

   jruby-1.7.1 [ i386 ]
   ree-1.8.7-2012.02 [ i686 ]
   ruby-1.8.7-p374 [ i686 ]
   ruby-1.9.2-p320 [ i686 ]
   ruby-1.9.3-p0 [ i686 ]
   ruby-1.9.3-p362 [ i686 ]
   ruby-1.9.3-p392 [ i686 ]
   ruby-1.9.3-p448 [ i686 ]
   ruby-1.9.3-p484 [ i686 ]
   ruby-2.0.0-p0 [ i686 ]
 * ruby-2.0.0-p247 [ i686 ]
   ruby-2.0.0-p353 [ i686 ]
   ruby-2.0.0-p451 [ i686 ]
   ruby-2.0.0-preview2 [ i686 ]
=> ruby-2.1.0 [ i686 ]
   ruby-head [ i686 ]

# => - current
# =* - current && default
#  * - default
Run Code Online (Sandbox Code Playgroud)

红宝石:

joe@warpaint ~/dev/project (master) $ ruby -v
ruby 2.1.0p0 (2013-12-25 revision 44422) [i686-linux]
Run Code Online (Sandbox Code Playgroud)

Joe*_*Leo 10

事实证明这是一个捆绑问题.一些挖掘引发了我这个问题:https: //github.com/bundler/bundler/issues/2355,由@indirect解决并提及使用Bundler.with_clean_env(更多关于此命令).

现在,上面的任务变为:

  1 task :call_heroku do     
  2   Bundler.with_clean_env { p `heroku pgbackups:url --remote staging` }
  3 end    
Run Code Online (Sandbox Code Playgroud)

一切都很好!