5

nginx 上で動作する Rails アプリケーション用に OSX Web サーバーをセットアップしました。サーバーを手動で起動すると Rails アプリは正常に動作しますが、サーバーを再起動すると常にパッセンジャー エラー メッセージが表示されます。

ロードするファイルがありません --bundler

手動で設定した起動デーモンで何かをしなければならないと思います:

# /Library/LaunchDaemons/org.nginx.ngnx.plist

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>Label</key>
    <string>nginx</string>
    <key>UserName</key>
    <string>MyUser</string>
    <key>ProgramArguments</key>
    <array>
        <string>/usr/local/Cellar/nginx/1.0.11/sbin/nginx</string>
        <string>-g</string>
        <string>daemon off;</string>
    </array>
    <key>KeepAlive</key>
    <true/>
    <key>NetworkState</key>
    <true/>
    <key>LaunchOnlyOnce</key>
    <true/>
</dict>
</plist>

ご覧のとおりMyUser、plist で UserName として使用しています。ブート後に nginx サーバーが起動し、MyUser として実行されますが、このエラー メッセージが表示されます。

コマンドラインで再起動すると、sudo nginx -s stop && nginxすべて正常に動作します。

理由はありますか?

編集

私のnginx.confは次のようになります:

env GEM_HOME=/usr/local/rvm/gems/ruby-1.9.2-p290@rails311/gems;
worker_processes 1;

events {
  worker_connections 1024;
}

http {
  include mime.types;
  default_type application/octet-stream;
  sendfile on;
  keepalive_timeout     60 60;
  send_timeout          120;

  recursive_error_pages on;

  error_log  /var/log/nginx/error.log;
  access_log  /var/log/nginx/access.log;

  gzip on;
  gzip_http_version 1.1;
  gzip_comp_level 4;
  gzip_proxied any;
  gzip_vary on;
  gzip_min_length 1100;
  gzip_buffers 32 16k;

  #server_tokens off;
  tcp_nopush    on;
  tcp_nodelay   on;
  keepalive_requests 0;

  passenger_default_user eveadmin;
  passenger_default_group staff;
  passenger_root /usr/local/rvm/gems/ruby-1.9.2-p290@rails311/gems/passenger-3.0.12;
  passenger_ruby /usr/local/rvm/rubies/ruby-1.9.2-p290/bin/ruby;


  server {
     listen 8444;
     #server_name intranet.local;
     root /Users/eveadmin/rails/intranet/public;
     passenger_enabled on;
     rails_env development;
  }
}

私が得るエラー

4

4 に答える 4

0

nginx.confでpassenger_default_userとpassenger_default_groupを設定してみてください。

デフォルト値はnobodyで、問題が発生した可能性があります。

詳細については、 PhusionPassengerユーザーガイドを参照してください。

于 2012-06-21T12:25:56.920 に答える
0

rubygems または bundler をインストールするときに sudo を使用しましたか? その場合は、ローカルに再インストールしてみてください。

于 2012-06-22T18:10:08.473 に答える
0

バンドラーでもこの問題を経験しました。特定の環境では、sudo を使用してバンドルを実行すると、表示されているエラーが発生し、sudo を使用せずに実行すると正常に動作します。

ユーザーのシェル環境(おそらくbash)がロードされていないため、変数$PATHと変数が設定されていないことが原因である可能性があると思います。$GEM_HOMEたぶん、コマンドを次のように変更する必要があります。

/bin/bash -l -c '/usr/local/Cellar/nginx/1.0.11/sbin/nginx'

それでもうまくいかない場合は、起動デーモンから UserName キーを取り出して、何が起こるか見てみましたか?

于 2012-06-22T22:50:26.147 に答える
0

私の2セント:nginx構成でGEM_HOME環境変数を設定してみてください。

于 2012-06-17T10:40:22.603 に答える