nginx,passenger,rails:没有这样的文件加载--bundler

时间:2012-05-30 11:18:12

标签: ruby-on-rails nginx passenger

我为在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>

如您所见,我在plist中使用MyUser作为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;
  }
}

error i get

4 个答案:

答案 0 :(得分:0)

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

答案 1 :(得分:0)

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

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

有关详细信息,请参阅Phusion Passenger users guide

答案 2 :(得分:0)

安装rubygems或bundler时是否使用过sudo?如果是这样,请尝试在本地重新安装。

答案 3 :(得分:0)

我也遇到过这个问题。在某些环境中,如果我运行bundle w / sudo,我会得到你看到的错误,如果我用sudo运行它,那么它运行正常。

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

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

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