为什么这条线在DreamHost上使用Passenger打破了Rails?

时间:2008-10-22 04:39:23

标签: ruby-on-rails passenger dreamhost

好的,所以我在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 个答案:

答案 0 :(得分:3)

我在DreamHost上遇到了同样的问题。冻结铁轨并拆开所有宝石让我超越它。

rake rails:freeze:gems
rake gems:unpack:dependencies

答案 1 :(得分:1)

我的猜测是因为Dreamhost上新版本的Rails宝石而破坏了。至少,当boot.rb等事情爆发时,这就是我的问题。

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

答案 2 :(得分:0)

呀 - 问题不在boot.rb中 - 只是boot.rb是实际加载rails的地方。

如果你指定了一个在dreamhost片上不存在的Rails版本,那么你会得到这样的错误。如果您要么升级项目,启动一个新项目(并且忘记您同时升级了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,但却默默地失败了 - 例如,对某个版本的机架的依赖性让我感到不安。但是你也可能有其他的gem依赖

如果您运行rake gems,您将能够列出项目所需的所有宝石 - 确保它们已经安装好。

然后,作为一种粗暴的烟雾测试,尝试运行script/console - 如果你错过了一个重要的铁轨宝石,script/console将无法加载并且应该失败,给你一个通知你需要的宝石。

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

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