首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Hostmonster fcgi上的Redmine 2: Rails应用程序启动失败

Hostmonster fcgi上的Redmine 2: Rails应用程序启动失败
EN

Stack Overflow用户
提问于 2012-05-24 18:50:59
回答 2查看 5.7K关注 0票数 2

我一直遵循安装说明,直到configuration部分,在hostmonster上安装红地雷2。当运行domain.com/redmine时,我总是有500个错误

代码语言:javascript
复制
Rails application failed to start properly

我在log/production.log.中没有任何关于这个错误的日志。以下是文件:

代码语言:javascript
复制
OpenIdAuthentication.store is nil. Using in-memory store.
Creating scope :open. Overwriting existing method Version.open.
Creating scope :active. Overwriting existing method User.active.
DEPRECATION WARNING: The InstanceMethods module inside ActiveSupport::Concern will be no longer included automatically. Please define instance methods directly in CollectiveIdea::Acts::NestedSet::Model instead. (called from include at /home1/iptechin/rails_apps/redmine200/lib/plugins/awesome_nested_set/lib/awesome_nested_set/awesome_nested_set.rb:58)
DEPRECATION WARNING: The InstanceMethods module inside ActiveSupport::Concern will be no longer included automatically. Please define instance methods directly in CollectiveIdea::Acts::NestedSet::Model instead. (called from include at /home1/iptechin/rails_apps/redmine200/lib/plugins/awesome_nested_set/lib/awesome_nested_set/awesome_nested_set.rb:58)
Creating scope :open. Overwriting existing method Issue.open.
Migrating to Setup (1)
Migrating to IssueMove (2)
Migrating to IssueAddNote (3)
Migration lines...........................etc.........
Migrating to AddAuthSourcesFilter (20120301153455)
Migrating to ChangeRepositoriesToFullSti (20120422150750)
OpenIdAuthentication.store is nil. Using in-memory store.
Creating scope :open. Overwriting existing method Version.open.
Creating scope :active. Overwriting existing method User.active.
DEPRECATION WARNING: The InstanceMethods module inside ActiveSupport::Concern will be no longer included automatically. Please define instance methods directly in CollectiveIdea::Acts::NestedSet::Model instead. (called from include at /home1/iptechin/rails_apps/redmine200/lib/plugins/awesome_nested_set/lib/awesome_nested_set/awesome_nested_set.rb:58)
DEPRECATION WARNING: The InstanceMethods module inside ActiveSupport::Concern will be no longer included automatically. Please define instance methods directly in CollectiveIdea::Acts::NestedSet::Model instead. (called from include at /home1/iptechin/rails_apps/redmine200/lib/plugins/awesome_nested_set/lib/awesome_nested_set/awesome_nested_set.rb:58)
Creating scope :open. Overwriting existing method Issue.open.

我的红鼠狼应该和fcgi一起工作,下面是我的public/.htaccess

代码语言:javascript
复制
# General Apache options
<IfModule mod_fastcgi.c>
    AddHandler fastcgi-script .fcgi
</IfModule>
<IfModule mod_fcgid.c>
AddHandler fcgid-script .fcgi
</IfModule>
<IfModule mod_cgi.c>
AddHandler cgi-script .cgi
</IfModule>
Options +SymLinksIfOwnerMatch +ExecCGI

RewriteEngine On

RewriteRule ^$ index.html [QSA]
RewriteRule ^([^.]+)$ $1.html [QSA]
RewriteCond %{REQUEST_FILENAME} !-f
<IfModule mod_fastcgi.c>
RewriteRule ^(.*)$ dispatch.fcgi [QSA,L]
</IfModule>
<IfModule mod_fcgid.c>
RewriteRule ^(.*)$ dispatch.fcgi [QSA,L]
</IfModule>
<IfModule mod_cgi.c>
RewriteRule ^(.*)$ dispatch.cgi [QSA,L]
</IfModule>

ErrorDocument 500 "<h2>Application error</h2>Rails application failed to start properly"

这是我的public/dispatch.fcgi

代码语言:javascript
复制
#!/usr/bin/env ruby

require File.dirname(__FILE__) + '/../config/boot'
require File.dirname(__FILE__) + '/../config/environment'

class Rack::PathInfoRewriter
  def initialize(app)
    @app = app
  end

  def call(env)
    env.delete('SCRIPT_NAME')
    parts = env['REQUEST_URI'].split('?')
    env['PATH_INFO'] = parts[0]
    env['QUERY_STRING'] = parts[1].to_s
    @app.call(env)
  end
end

Rack::Handler::FastCGI.run Rack::PathInfoRewriter.new(RedmineApp::Application)

是否有任何错误配置?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-05-28 13:39:11

这是一个宝石路径问题。由于这个没有这样的文件来装载-在Rails 3.2中与乘客一起安装,我在/public/..htaccess中添加了这一行:

代码语言:javascript
复制
SetEnv GEM_PATH /path-to-ruby-gems/ruby/gems
票数 1
EN

Stack Overflow用户

发布于 2012-05-25 09:00:41

是否安装了所有正确的宝石?

这是我的dispatch.fcgi:

代码语言:javascript
复制
   #!/usr/bin/ruby
   #
   # You may specify the path to the FastCGI crash log (a log of unhandled
   # exceptions which forced the FastCGI instance to exit, great for debugging)
   # and the number of requests to process before running garbage collection.
   #
   # By default, the FastCGI crash log is RAILS_ROOT/log/fastcgi.crash.log
   # and the GC period is nil (turned off).  A reasonable number of requests
   # could range from 10-100 depending on the memory footprint of your app.
   #
   # Example:
   #   # Default log path, normal GC behavior.
   #   RailsFCGIHandler.process!
   #
   #   # Default log path, 50 requests between GC.
   #   RailsFCGIHandler.process! nil, 50
   #
   #   # Custom log path, normal GC behavior.
   #   RailsFCGIHandler.process! '/var/log/myapp_fcgi_crash.log'
   #
   require File.dirname(__FILE__) + "/../config/environment"
   require 'fcgi_handler'

   RailsFCGIHandler.process!

还有我的.htaccess

代码语言:javascript
复制
# General Apache options
<IfModule mod_fastcgi.c>
    AddHandler fastcgi-script .fcgi
</IfModule>
<IfModule mod_fcgid.c>
#   AddHandler fcgid-script .fcgi
</IfModule>
<IfModule mod_cgi.c>
#   AddHandler cgi-script .cgi
</IfModule>
# For security reasons, Option followsymlinks cannot be overridden.
#Options +FollowSymLinks +ExecCGI
Options +SymLinksIfOwnerMatch +ExecCGI

# If you don't want Rails to look in certain directories,
# use the following rewrite rules so that Apache won't rewrite certain requests
#
# Example:
#   RewriteCond %{REQUEST_URI} ^/notrails.*
#   RewriteRule .* - [L]

# Redirect all requests not available on the filesystem to Rails
# By default the cgi dispatcher is used which is very slow
#
# For better performance replace the dispatcher with the fastcgi one
#
# Example:
#   RewriteRule ^(.*)$ dispatch.fcgi [QSA,L]
RewriteEngine On

# If your Rails application is accessed via an Alias directive,
# then you MUST also set the RewriteBase in this htaccess file.
#
# Example:
#   Alias /myrailsapp /path/to/myrailsapp/public
#   RewriteBase /myrailsapp

Options -MultiViews
PassengerResolveSymlinksInDocumentRoot on
#Change to your environment
RailsEnv production

RewriteBase /
RewriteRule ^$ index.html [QSA]
RewriteRule ^([^.]+)$ $1.html [QSA]
RewriteCond %{REQUEST_FILENAME} !-f
<IfModule mod_fastcgi.c>
    RewriteRule ^(.*)$ dispatch.fcgi [QSA,L]
</IfModule>
<IfModule mod_fcgid.c>
    RewriteRule ^(.*)$ dispatch.fcgi [QSA,L]
</IfModule>
<IfModule mod_cgi.c>
    RewriteRule ^(.*)$ dispatch.cgi [QSA,L]
</IfModule>

# In case Rails experiences terminal errors
# Instead of displaying this message you can supply a file here which will be rendered instead
#
# Example:
#   ErrorDocument 500 /500.html

ErrorDocument 500 "<h2>Application error</h2>Rails application failed to start properly"
#RewriteCond %{HTTP_HOST} ^redmine.acme-tech.net$ [OR]
#RewriteCond %{HTTP_HOST} ^www.redmine.acme-tech.net$
#RewriteRule ^(.*)$ "http\:\/\/127\.0\.0\.1\:12018\/$1" [P,L]

希望它能帮上忙

gj。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10743577

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档