4

好的,所以我在 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

4

3 回答 3

3

我在 DreamHost 上遇到了同样的问题。冻结铁轨并打开所有宝石的包装让我通过了它。

rake rails:freeze:gems
rake gems:unpack:dependencies
于 2009-05-19T23:46:53.187 回答
1

我的猜测是,由于 Dreamhost 上的 Rails gems 的更新版本,您正在崩溃。至少,当 boot.rb 之类的东西出现问题时,这就是我的问题。

尝试将开发环境中的 gem 冻结到 vendor/rails 目录中。

于 2008-10-22T15:07:56.523 回答
0

是的 - 问题并不真正存在boot.rb- 它只是boot.rb实际加载 rails 的地方。

因此,如果您指定的 Rails 版本在您的 dreamhost 切片中不存在,您将收到类似的错误。如果您升级项目、启动新项目(同时忘记升级 Rails)或者您仍在使用旧版本的 Rails 并且现在已从您正在使用的 dreamhost 服务器中删除,则可能会发生这种情况上。

要弄清楚哪个是,请查看config/environment.rb将显示如下内容的行:

RAILS_GEM_VERSION = '2.3.4' unless defined? RAILS_GEM_VERSION

然后 ssh 到您的 dreamhost 服务器并键入gem list并查看您的版本是否在列表中。

如果没有,您可以尝试几种选择。假设您使用的版本是 2.3.4 首先,尝试:gem install rails -v=2.3.4然后重新启动。这可能就是所有需要的。如果这不起作用,请尝试冻结并拆开宝石(根据此处的其他答案)。

还有另一种可能性——你实际上错过了一个 Rails 依赖的 gem,但它正在默默地失败——例如,对某个版本的 rack 的依赖让我有一次失望。但是您可能还有其他 gem 依赖项

如果您运行rake gems,您将能够列出您的项目知道它需要的所有 gem - 确保一开始就安装了它们。

然后,作为一种粗略的冒烟测试,尝试运行script/console- 如果您缺少重要的 rails gem,script/console将不会加载并且应该失败,并通知您需要的 gem。

更新:如果您尝试运行 v 2.3.5,您可能还会遇到此问题: Bypassing rack version error using Rails 2.3.5

在这种情况下,您需要按照那里的说明进行操作。

于 2010-03-12T13:40:02.343 回答