5

我为在 nginx 上运行的 rails 应用程序设置了一个 OSX 网络服务器。当我手动启动服务器时,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

安装 ruby​​gems 或 bundler 时是否使用了 sudo?如果是这样,请尝试在本地重新安装它们。

于 2012-06-22T18:10:08.473 回答
0

我在使用 bundler 时也遇到过这个问题。在某些环境中,如果我使用 sudo 运行 bundle,我会收到您所看到的错误,如果我在没有 sudo 的情况下运行它,那么它可以正常工作。

我相信这可能是因为您的$PATH$GEM_HOME变量未设置 b/c 您的用户的 shell 环境(可能是 bash)未加载。也许你应该把你的命令改成这样:

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

如果这不起作用,您是否尝试过将 UserName 键从启动守护程序中取出,看看会发生什么?

于 2012-06-22T22:50:26.147 回答
0

尝试在你的 nginx.conf 中设置passenger_default_user 和passenger_default_group。

默认值为nobody,这可能会导致您的问题。

有关详细信息,请参阅Phusion 乘客用户指南

于 2012-06-21T12:25:56.920 回答
0

我的 2 美分:尝试在 nginx 配置中设置 GEM_HOME 环境变量。

于 2012-06-17T10:40:22.603 回答