Уровень стека Ruby 2.4 и Rails 4 слишком глубокий (SystemStackError)

Я пытаюсь запустить недавно созданный проект в Rails 4.0.8, но я получаю сообщение об ошибке:

    rails s
=> Booting WEBrick
=> Rails 4.0.8 application starting in development on http://0.0.0.0:3000
=> Run `rails server -h` for more startup options
=> Ctrl-C to shutdown server
/usr/local/lib/ruby/gems/2.4.0/gems/activesupport-4.0.8/lib/active_support/core_ext/numeric/conversions.rb:121: warning: constant ::Fixnum is deprecated
/usr/local/lib/ruby/gems/2.4.0/gems/activesupport-4.0.8/lib/active_support/core_ext/numeric/conversions.rb:121: warning: constant ::Bignum is deprecated
Exiting
/usr/local/lib/ruby/gems/2.4.0/gems/activesupport-4.0.8/lib/active_support/core_ext/numeric/conversions.rb:124:in `block (2 levels) in <class:Numeric>': stack level too deep (SystemStackError)
    from /usr/local/lib/ruby/gems/2.4.0/gems/activesupport-4.0.8/lib/active_support/core_ext/numeric/conversions.rb:131:in `block (2 levels) in <class:Numeric>'
    from /usr/local/lib/ruby/gems/2.4.0/gems/activesupport-4.0.8/lib/active_support/core_ext/numeric/conversions.rb:131:in `block (2 levels) in <class:Numeric>'
    from /usr/local/lib/ruby/gems/2.4.0/gems/activesupport-4.0.8/lib/active_support/core_ext/numeric/conversions.rb:131:in `block (2 levels) in <class:Numeric>'
    from /usr/local/lib/ruby/gems/2.4.0/gems/activesupport-4.0.8/lib/active_support/core_ext/numeric/conversions.rb:131:in `block (2 levels) in <class:Numeric>'
    from /usr/local/lib/ruby/gems/2.4.0/gems/activesupport-4.0.8/lib/active_support/core_ext/numeric/conversions.rb:131:in `block (2 levels) in <class:Numeric>'
    from /usr/local/lib/ruby/gems/2.4.0/gems/activesupport-4.0.8/lib/active_support/core_ext/numeric/conversions.rb:131:in `block (2 levels) in <class:Numeric>'
    from /usr/local/lib/ruby/gems/2.4.0/gems/activesupport-4.0.8/lib/active_support/core_ext/numeric/conversions.rb:131:in `block (2 levels) in <class:Numeric>'
    from /usr/local/lib/ruby/gems/2.4.0/gems/activesupport-4.0.8/lib/active_support/core_ext/numeric/conversions.rb:131:in `block (2 levels) in <class:Numeric>'
     ... 5532 levels...
    from /usr/local/lib/ruby/gems/2.4.0/gems/railties-4.0.8/lib/rails/commands.rb:71:in `tap'
    from /usr/local/lib/ruby/gems/2.4.0/gems/railties-4.0.8/lib/rails/commands.rb:71:in `<top (required)>'
    from bin/rails:4:in `require'
    from bin/rails:4:in `<main>'

Рубиновая версия:

Rails 4.0.8

Мой Gemefile:

source 'https://rubygems.org'

# Bundle edge Rails instead: gem 'rails', github: 'rails/rails'
gem 'rails', '4.0.8'

# Use sqlite3 as the database for Active Record
gem 'sqlite3'

# Use SCSS for stylesheets
gem 'sass-rails', '~> 4.0.2'

# Use Uglifier as compressor for JavaScript assets
gem 'uglifier', '>= 1.3.0'

# Use CoffeeScript for .js.coffee assets and views
gem 'coffee-rails', '~> 4.0.0'

# See https://github.com/sstephenson/execjs#readme for more supported runtimes
# gem 'therubyracer', platforms: :ruby

# Use jquery as the JavaScript library
gem 'jquery-rails'

# Turbolinks makes following links in your web application faster. Read more: https://github.com/rails/turbolinks
gem 'turbolinks'

# Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder
gem 'jbuilder', '~> 1.2'
gem 'json', github: 'flori/json', branch: 'v1.8'
group :doc do
  # bundle exec rake doc:rails generates the API under doc/api.
  gem 'sdoc', require: false
end

Я попытался переустановить рельсы, потому что до того, как у меня на компьютере установлено 5.0 Rails.

Местные жемчужины:

*** LOCAL GEMS ***

autoprefixer-rails (6.6.0)
coffee-rails (4.2.1, 4.0.1)
font-awesome-rails (4.7.0.1)
jquery-atwho-rails (1.3.2)
jquery-rails (4.2.2, 3.1.4)
rails (4.0.8, 4.0.0)
rails-dom-testing (2.0.2)
rails-html-sanitizer (1.0.3)
rails_12factor (0.0.3)
rails_serve_static_assets (0.0.5)
rails_stdout_logging (0.0.5)
sass-rails (5.0.6, 4.0.5)
sprockets-rails (3.2.0, 2.3.3, 2.0.1)

Meybe unistall: ruby ​​и rails решат эту проблему, но я не хочу этого делать. К счастью, я хотел установить обе версии направляющих, например, рельсы 4 и 5. Возможна ли такая конфигурация?

3 ответа

Решение

В Ruby 2.4 произошла унификация целочисленных типов (т.е. Fixnum а также Bignum теперь то же самое Integer). Это приводит к нескольким несовместимостям с существующими драгоценными камнями, которые основаны на различии классов.

Более старые версии ActiveSupport относятся к тем, которым не нравится это объединение, и оно пытается его игнорировать при попытке сериализации данных. Таким образом, у вас есть один из двух вариантов:

  • Вы можете понизить версию Ruby до версии 2.4, например, Ruby 2.3.x.
  • Или вы можете обновить Rails до более новой версии. Желательно, чтобы это был Rails 5.x. В ветке 4.2-stable, выпущенной вместе с Rails 4.2.8, есть патч, делающий его первой версией серии Rails 4.2, официально поддерживающей Ruby 2.4. Более ранние версии Rails не совместимы с Ruby 2.4.

У меня та же ошибка, но я не хочу обновляться до 5.0, мое приложение очень большое и обновление занимает слишком много времени. Я модернизирую Rails 4.1.7 к Rails to 4.2.8 первый релиз Rails с Ruby 2.4 служба поддержки:

в Gemfile:

gem 'rails', '4.2.8'

Затем:

bundle update rails

Что касается ошибки, вы используете только что выпущенный Ruby 2.4, который, скорее всего, Rails и ActiveSupport (особенно их старые версии) еще не поддерживают.

В этом руководстве по Rails говорится, что ваша версия Rails (4.0.8) предпочитает Ruby 2.0.

Вы можете исправить ошибку, обновив установку Rails (gem 'rails', '5.0') или переход на более старую версию Ruby с помощью менеджера версий (например, $ rvm install 2.3.0; rvm use 2.3.0).

Другие вопросы по тегам