web-dev-qa-db-ja.com

Rails app with / Nginx、Passengerで禁止されている403

まず、お詫び申し上げます。403Forbiddenの質問はRails/Nginxのインストールでよくある質問ですが、これまで読んだ回答で解決できませんでした。

免責事項:RailsアプリをHeroku以外の場所にデプロイするのは今回が初めてです。優しくしてください。;)

状況:私はRailsアプリをUbuntu 12.04サーバーで実行し、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;
        }

私はこれを解決するための助けをいただければ幸いです。ありがとう!

[〜#〜] update [〜#〜]私はそれ以来、誤ったpassenger_Rubyパスを修正しましたが、Nginxを再起動した後でも403 Forbiddenが持続しています。

14
cole

あなたの乗客のインストールのパスを確認することができます

passenger-config --root

Rubyインストールのパス

which Ruby

次に、nginx.confに挿入されたものと比較します。

28

同じエラーが発生しました。私の場合、場所/ {}エントリを削除して修正しました。 -または、ユーザーがRailsプロジェクトへのアクセス許可を持っていることを確認してください

...
server {
    listen       80;
    server_name  127.0.0.1;
    passenger_enabled on;
    Rails_env production;
    root /www/kalender/public ;

    #charset koi8-r;

    access_log  /var/log/nginx/Host.access.log;

    #location / {
       #root   html;
        #index  index.html index.htm;
    #}
5

サーバーディレクティブにpassenger_enabled on;を追加するとうまくいきました。

4
ethicalhack3r

私はあなたと同じような設定を実行していて、nginx.confファイルで同じ問題がありました。 Nginxの落とし穴のページ を偶然見つけたので、解決に役立ちました。

あなたのファイルは私のものに似ているので、試してみたくなるかもしれない2つのことを共有します。

  1. まず、server {}ブロックとlocation {}ブロックの両方にrootパスがあります。上記のリンク先のドキュメントによると、必ずしも問題ではありませんが、「すべてのロケーションブロックにルートを追加すると、一致しないロケーションブロックにはルートがなくなります。」ロケーションブロックのルートを削除しましたが、サーバーブロックに保持しました。

  2. 'index'ディレクティブ(index index.html index.htm;)をロケーションブロックからhttp {}ブロック内に移動します。ロケーションブロックはこれを継承します。

これら2つのことを実行し、サーバーを再起動することでうまくいきました。

3
Sam M.

問題はlocation / {...}セクションにあります。passenger_enabled onserver {...}からlocation / {...}に伝播しません。

location / {...}を削除するか、passenger_enabled onを追加すると、機能するはずです。

2
Jxtps

また、デフォルトでpassenger.confという名前の乗客用の設定ファイルがあり、/etc/nginx/conf.d/passenger.confには正しいルートを配置する必要があります。これら2つのコマンドでルートを確認できます

passenger-config --root

そして

どのルビー

したがって、これらのルートを取得したら、passenger.confファイル内のルートと比較する必要があります。このような

#passenger-config --root
passenger_root /usr/share/Ruby/vendor_Ruby/phusion_passenger/locations.ini;
#which Ruby
passenger_Ruby /usr/local/rvm/rubies/Ruby-2.4.0/bin/Ruby;
passenger_instance_registry_dir /var/run/passenger-instreg;

したがって、この方法を使用する場合は、nginx.confのhttpセクションで作成することを忘れないでください。

include /etc/nginx/conf.d/passenger.conf

サーバーセクションに挿入するだけでなく

passenger_enabled on;
1
Vitaliy LiBrus

Railsアプリケーションが/でアクセス可能であると仮定して、/セクションのロケーションブロックを削除します。

Passenger_Rubyが選択したRuby versionのrvmラッパースクリプトを指していることを確認します

にアクセスするすべてのディレクトリに、ユーザー、グループ、その他のユーザーに実行権限を追加します

/var/www/Rails_app/public folder 
/var
/var/www
/var/www/Rails_app
/var/www/Rails_app/public_foler 
1
sam.ruby

ルートをサーバーブロック内と/ locationブロック内で2回宣言し、nginxにインデックスディレクティブを使用するように指示しています。パブリックフォルダーの後の「/」も削除する

これをやってみてください

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;

    }
}
0
iniy