Почему эта линия ломает Rails с Passenger на DreamHost? - PullRequest
4 голосов
/ 22 октября 2008

Хорошо, у меня на DreamHost настроено приложение Rails, и оно работало некоторое время назад, а теперь оно сломано. Я не знаю много о средах развертывания или что-то подобное, поэтому, пожалуйста, прости мое невежество. В любом случае, похоже, что в этой строке приложения происходит сбой в config / environment.rb:

require File.join(File.dirname(__FILE__), 'boot')

config / boot.rb довольно нормальный, но я все равно включу его сюда.

# Don't change this file!
# Configure your app in config/environment.rb and config/environments/*.rb

RAILS_ROOT = "#{File.dirname(__FILE__)}/.." unless defined?(RAILS_ROOT)

module Rails
  class << self
    def boot!
      unless booted?
        preinitialize
        pick_boot.run
      end
    end

    def booted?
      defined? Rails::Initializer
    end

    def pick_boot
      (vendor_rails? ? VendorBoot : GemBoot).new
    end

    def vendor_rails?
      File.exist?("#{RAILS_ROOT}/vendor/rails")
    end

    def preinitialize
      load(preinitializer_path) if File.exist?(preinitializer_path)
    end

    def preinitializer_path
      "#{RAILS_ROOT}/config/preinitializer.rb"
    end
  end

  class Boot
    def run
      load_initializer
      Rails::Initializer.run(:set_load_path)
    end
  end

  class VendorBoot < Boot
    def load_initializer
      require "#{RAILS_ROOT}/vendor/rails/railties/lib/initializer"
      Rails::Initializer.run(:install_gem_spec_stubs)
    end
  end

  class GemBoot < Boot
    def load_initializer
      self.class.load_rubygems
      load_rails_gem
      require 'initializer'
    end

    def load_rails_gem
      if version = self.class.gem_version
        gem 'rails', version
      else
        gem 'rails'
      end
    rescue Gem::LoadError => load_error
      $stderr.puts %(Missing the Rails #{version} gem. Please `gem install -v=#{version} rails`, update your RAILS_GEM_VERSION setting in config/environment.rb for the Rails version you do have installed, or comment out RAILS_GEM_VERSION to use the latest version installed.)
      exit 1
    end

    class << self
      def rubygems_version
        Gem::RubyGemsVersion if defined? Gem::RubyGemsVersion
      end

      def gem_version
        if defined? RAILS_GEM_VERSION
          RAILS_GEM_VERSION
        elsif ENV.include?('RAILS_GEM_VERSION')
          ENV['RAILS_GEM_VERSION']
        else
          parse_gem_version(read_environment_rb)
        end
      end

      def load_rubygems
        require 'rubygems'
        min_version = '1.1.1'
        unless rubygems_version >= min_version
          $stderr.puts %Q(Rails requires RubyGems >= #{min_version} (you have #{rubygems_version}). Please `gem update --system` and try again.)
          exit 1
        end

      rescue LoadError
        $stderr.puts %Q(Rails requires RubyGems >= #{min_version}. Please install RubyGems and try again: http://rubygems.rubyforge.org)
        exit 1
      end

      def parse_gem_version(text)
        $1 if text =~ /^[^#]*RAILS_GEM_VERSION\s*=\s*["']([!~<>=]*\s*[\d.]+)["']/
      end

      private
        def read_environment_rb
          File.read("#{RAILS_ROOT}/config/environment.rb")
        end
    end
  end
end

# All that for this:
Rails.boot!

У кого-нибудь есть идеи? Я не получаю никаких ошибок в журнале или на странице.

-fREW

Ответы [ 3 ]

3 голосов
/ 20 мая 2009

У меня была такая же проблема на DreamHost. Замораживание рельсов и распаковка всех драгоценных камней помогли мне преодолеть это.

rake rails:freeze:gems
rake gems:unpack:dependencies
1 голос
/ 22 октября 2008

Полагаю, вы ломаетесь из-за новой версии драгоценных камней Rails на Dreamhost. По крайней мере, это было моей проблемой, когда что-то вроде boot.rb взорвалось.

Попробуйте заморозить драгоценные камни из вашей среды разработки в каталоге vendor / rails.

0 голосов
/ 12 марта 2010

Да, проблема не в boot.rb, просто в boot.rb загружены рельсы.

Таким образом, вы получите ошибку, подобную этой, если вы указали версию Rails, которой просто нет в вашем срезе. Это может произойти, если вы либо обновите свой проект, начнете новый проект (и забудете, что тем временем обновили rails), либо если вы все еще используете старую версию rails и теперь она удалена с сервера Dreamhost, который вы используете. на.

Чтобы выяснить, что есть, посмотрите в config/environment.rb строку, которая будет выглядеть примерно так:

RAILS_GEM_VERSION = '2.3.4' unless defined? RAILS_GEM_VERSION

Затем отправьте ssh на сервер вашей мечты и наберите gem list и посмотрите, есть ли ваша версия в списке.

Если нет, попробуйте несколько вариантов. Допустим, вы используете версию 2.3.4 Для начала попробуйте: gem install rails -v=2.3.4, затем перезапустите. Это может быть все, что требуется. Если это не сработает, попробуйте заморозить и распаковать драгоценные камни (см. Другой ответ здесь).

Существует также другая возможность - что вы на самом деле упускаете драгоценный камень, от которого зависит рельс, но который молча терпит неудачу - например, зависимость от определенной версии стойки застала меня однажды. Но у вас могут быть и другие зависимости от драгоценных камней

Если вы запустите rake gems, вы сможете перечислить все драгоценные камни, о которых ваш проект знает, в которых он нуждается - убедитесь, что они установлены с самого начала.

Затем, в качестве грубого теста на дым, попробуйте запустить script/console - если вам не хватает драгоценного камня для рельсов, script/console не будет загружаться и выйдет из строя, давая вам уведомление о том, что вам нужно. .

Обновление : Если вы пытаетесь запустить v 2.3.5, вы также можете страдать от этой проблемы: Ошибка версии обхода стойки с использованием Rails 2.3.5

В этом случае вам нужно будет следовать инструкциям там.

...