在我的生产服务器上使用Rails,Passenger(都是3.0.5)和Nginx。据我所知,Rails应该显示public/404.html
或public/500.html
,而不是像ActiveRecord::RecordNotFound
或Unknown action
这样的开发错误,但这并未发生。我尝试删除config.ru文件,并在nginx.conf中设置rack_env或rails_env,但没有任何帮助。Rails 3 - 生产模式下的开发错误
这里是我的nginx.conf:
worker_processes 1;
events {
worker_connections 1024;
}
http {
passenger_root /home/makk/.rvm/gems/ruby-1.9.2-p0/gems/passenger-3.0.5;
passenger_ruby /home/makk/.rvm/bin/passenger_ruby;
#passenger_ruby /home/makk/.rvm/wrappers/ruby-1.9.2-p0/ruby;
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
server {
listen 80;
server_name localhost;
location/{
root /home/makk/projects/1server/deploy/current/public;
index index.html index.htm;
passenger_enabled on;
rack_env production;
recursive_error_pages on;
if (-f /home/makk/projects/1server/maintenance.html) {
return 503;
}
error_page 404 /404.html;
error_page 500 502 504 /500.html;
error_page 503 @503;
}
location @503 {
error_page 405 = /maintenance.html;
# Serve static assets if found.
if (-f $request_filename) {
break;
}
rewrite ^(.*)$ /maintenance.html break;
}
location ~ ^(\/phpmyadmin\/)(.*)$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_split_path_info ^(\/phpmyadmin\/)(.*)$;
fastcgi_param SCRIPT_FILENAME /usr/share/phpmyadmin/$fastcgi_path_info;
include fastcgi_params;
}
}
}
看来,这个问题重复this one,但没有工作的建议。
UPD:我在同一台PC上都有开发和生产应用程序。在生产中,由于local_request?
方法的原因,Rails忽略config.consider_all_requests_local = false
(在/config/environments/production.rb中)。所以,可能的解决方案之一如下(从here拍摄):
# config/initializers/local_request_override.rb
module CustomRescue
def local_request?
return false if Rails.env.production? || Rails.env.staging?
super
end
end
ActionController::Base.class_eval do
include CustomRescue
end
或者为Rails 3:
class ActionDispatch::Request
def local?
false
end
end
几乎看我的问题,但没有帮助。请参阅更新的nginx.conf。 – sunki
你的rails“public”目录中是否有500.html和404.html? – Brandon
当然可以...... – sunki