herokuapp/vendor/bundle显示了错误版本的ruby



我在生产中遇到了一个开发中没有发生的错误。在堆栈跟踪中,gem使用了错误版本的ruby(2.1.0),但我在gemfile中指定了2.1.3,并对ruby版本进行了heroku故障排除。基于其他stackoverflow信息,ruby版本在这里起了作用。有人知道如何将应用程序/供应商/捆绑包更新到最新版本吗?

这是我的错误,发生在一个Resque工作人员身上。。。

undefined method `name' for nil:NilClass
/app/vendor/bundle/ruby/2.1.0/gems/psych-2.0.6/lib/psych/visitors/yaml_tree.rb:72:in `block in initialize'
/app/vendor/bundle/ruby/2.1.0/gems/psych-2.0.6/lib/psych/visitors/yaml_tree.rb:74:in `yield'
/app/vendor/bundle/ruby/2.1.0/gems/psych-2.0.6/lib/psych/visitors/yaml_tree.rb:74:in `block in initialize'
/app/vendor/bundle/ruby/2.1.0/gems/psych-2.0.6/lib/psych/visitors/yaml_tree.rb:74:in `yield'
/app/vendor/bundle/ruby/2.1.0/gems/psych-2.0.6/lib/psych/visitors/yaml_tree.rb:74:in `block in initialize'
/app/vendor/bundle/ruby/2.1.0/gems/psych-2.0.6/lib/psych/visitors/yaml_tree.rb:74:in `yield'
/app/vendor/bundle/ruby/2.1.0/gems/psych-2.0.6/lib/psych/visitors/yaml_tree.rb:74:in `block in initialize'
/app/vendor/bundle/ruby/2.1.0/gems/psych-2.0.6/lib/psych/visitors/yaml_tree.rb:150:in `yield'
/app/vendor/bundle/ruby/2.1.0/gems/psych-2.0.6/lib/psych/visitors/yaml_tree.rb:150:in `accept'
/app/vendor/bundle/ruby/2.1.0/gems/psych-2.0.6/lib/psych/visitors/yaml_tree.rb:114:in `push'
/app/vendor/bundle/ruby/2.1.0/gems/psych-2.0.6/lib/psych.rb:409:in `dump'
...snip...

这是我的ruby版本。。。

heroku run "ruby --version"
ruby 2.1.3p242 (2014-09-19 revision 47630) [x86_64-linux]

这是/app/vendor/bundle中的内容。。。

heroku run "ls /app/vendor/bundle/ruby"
2.1.0

这是我的Gemfile红宝石声明。。。。

source 'https://rubygems.org'
group :default do
  # current stable (heroku needs this listed)
  ruby '2.1.3'
  gem 'rails', '4.1.1'
  gem 'redis' # queue mechanism
  gem 'resque', "~> 1.22.0", :require => "resque/server"
  gem 'resque_mailer' # mailer queue
  gem 'resque-scheduler' # job scheduler
  # postgres and database
  gem 'pg' # postgres
  gem 'activerecord-import' # bulk sql insert
  gem 'seed-fu', '~> 2.3' # db seed data
  # APIs
  gem 'bitly'
  gem 'feedjira' # RSS feeds
  gem 'fullcontact'
  gem 'httparty'# rest api client
  gem 'twilio-ruby' # SMS
  gem 'twitter'
  gem 'twitter-text' # convert twitter, links, hashtags and users
  gem 'yahoo-finance', require: 'yahoo_finance'
  # WEB....
  # Use unicorn as the app server
  gem 'unicorn'
  # javascript
  gem 'jquery-rails'
  gem 'uglifier', '>= 1.3.0' # compressor for js assets
  gem 'coffee-rails', '~> 4.0.0'
  # UI/CSS
  gem 'sass-rails', '~> 4.0.0'
  gem 'bootstrap-sass'
  gem 'jquery-ui-rails'
  gem 'jqcloud-rails' # word cloud
  gem 'footable-rails' # mobile responsive table
  gem 'font-awesome-sass'# icons
  gem 'highcharts-rails'
  # rails
  gem 'turbolinks'
  gem 'simple_form'
  # admin interface
  gem 'rails_admin' # models admin interface
  gem "psych", "~> 2.0.5" # needed for rails_admin
  # user authentication
  gem 'devise'
  gem 'domp'
  gem 'omniauth'
  gem 'omniauth-twitter'
  gem 'omniauth-stocktwits', :git => 'https://github.com/jesseyoungmann/omniauth-stocktwits.git'
  # app support
  gem 'bcrypt', '~> 3.1.2' # for active model secure password
  gem 'kaminari', :git => 'https://github.com/musicglue/kaminari.git' # pagination
end

# docs
group :doc do
  # bundle exec rake doc:rails generates the API under doc/api.
  gem 'sdoc', require: false
end

# test
group :test do
  gem "capybara"
  gem 'factory_girl_rails'
  gem 'faker'
  gem 'rspec-rails'
  gem 'selenium-webdriver'
  gem 'simplecov', :require => false
  gem 'vcr', '~> 2.8.0'
  gem 'webmock', '~> 1.15.0'
end
# development
group :development do
  gem 'foreigner', '~> 1.6.1' # foreign key generator
  gem 'rails_layout'
  # profilers
  gem 'rack-mini-profiler'
  gem 'ruby-prof'
end
group :production do
  gem 'newrelic_rpm'
  gem 'rails_12factor' # heroku
end

谢谢!

一个可能的解决方案是在应用程序的根目录中创建一个.ruby-version文件,并简单地将2.1.3放入其中,这样您的应用程序在生产和开发中就会始终使用该版本。我过去也遇到过类似的问题,这对我来说很有用。

复制:

  • 为什么Heroku堆栈跟踪显示Ruby 1.9.1正在使用

答案与此相同:

  • 为什么我们要将Ruby1.9.2/1.9.3gems安装到1.9.1文件夹中

最新更新