まず、お詫び申し上げます。403 Forbidden の質問が Rails/Nginx のインストールでよくある質問であることは知っていますが、これまでに読んだ回答のどれも解決できませんでした。
免責事項: Heroku 以外の場所に Rails アプリをデプロイするのはこれが初めてです。優しくしてください。;)
状況: Ubuntu 12.04 サーバー上で実行されている Rails アプリがあり、Nginx (Passenger と共にインストールされます) を実行しています。
アプリをサーバーに正しくデプロイしましたが、サイトにアクセスしようとすると、403 Forbidden エラーが発生します。
エラーログを確認すると、次のように表示されます。
2013/10/23 22:47:01 [error] 27954#0: *105 directory index of "/var/www/colepeters.com/current/public/" is forbidden, client: 50.3…server: colepeters.com, request: "GET / HTTP/1.1", host: "colepeters.com"
2013/10/23 22:47:10 [error] 27954#0: *106 directory index of "/var/www/colepeters.com/current/public/" is forbidden, client: 184…server: colepeters.com, request: "GET / HTTP/1.1", host: "colepeters.com"
2013/10/23 22:47:12 [error] 27954#0: *107 directory index of "/var/www/colepeters.com/current/public/" is forbidden, client: 151…server: colepeters.com, request: "GET / HTTP/1.1", host: "colepeters.com"
ただし、このディレクトリのアクセス許可を確認すると、Nginx を使用するようにセットアップしたユーザーが読み取りと実行の両方のアクセス許可を持っていることがわかります。
nginx.conf からの関連情報は次のとおりです。
user XXXX;
worker_processes 1;
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
events {
worker_connections 1024;
}
http {
passenger_root /home/cole/.rvm/gems/ruby-2.0.0-p247/gems/passenger-4.0.21;
passenger_ruby /home/cole/.rvm/wrappers/ruby-2.0.0-p247/ruby;
include mime.types;
default_type application/octet-stream;
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
server {
listen 80;
server_name colepeters.com www.colepeters.com;
passenger_enabled on;
root /var/www/colepeters.com/current/public/;
rails_env production;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
root /var/www/colepeters.com/current/public;
index index.html index.htm;
# autoindex on;
}
これを解決するための助けをいただければ幸いです。ありがとう!
更新 以来、誤ったpassenger_rubyパスを修正しましたが、Nginxを再起動した後でも、403 Forbiddenが持続しています。