我正在使用Passenger Nginx来运行Rails应用程序.如果我使用“rails_env开发”;该应用程序工作正常.
但如果我在生产模式下运行,我会得到“我们很抱歉,但出了点问题.”
我确实运行了db:migrate for production,我可以正常访问数据库.
奇怪的是,我没有在日志中获得任何新条目(Nginx和rails one),我确保Nginx用户可以在它们上面写.
如果我运行rails console生产,它工作正常:
# rails console production
Loading production environment (Rails 3.2.0)
1.9.3-p125 :001 >
@H_301_15@
关于可能发生的事情的任何想法?我还应该检查什么?
– – 编辑 – –
在@BenLee建议将passenger_debug_log_file添加到Nginx.conf之后,我开始为开发和生产带来这个错误:
# /etc/init.d/Nginx restart
Nginx: the configuration file /opt/Nginx/conf/Nginx.conf Syntax is ok
Nginx: [alert] Unable to start the Phusion Passenger watchdog: it seems to have crashed during startup for an unknown reason,with exit code 1 (-1: Unknown error)
Nginx: configuration file /opt/Nginx/conf/Nginx.conf test is successful
Parando o Nginx: [ OK ]
Iniciando o Nginx: Nginx: [alert] Unable to start the Phusion Passenger watchdog: it seems to have crashed during startup for an unknown reason,with exit code 1 (-1: Unknown error)
[ OK ]
@H_301_15@
我搜索了这个错误,但我还没有找到解决方案.看门狗似乎存在并且位于正确的位置:
# ls -lh /usr/local/rvm/gems/ruby-1.9.3-p125/gems/passenger-3.0.11/agents/
total 7,8M
drwxr-sr-x 2 root rvm 4,0K Fev 22 23:34 Nginx
-rwxr-xr-x 1 root rvm 4,6M Fev 22 23:35 PassengerLoggingAgent
-rwxr-xr-x 1 root rvm 3,3M Fev 22 23:34 PassengerWatchdog
@H_301_15@
如果我删除passenger_debug_log_file则正常启动.但原来的问题又回来了,应用程序不能在生产模式下运行.
要做到这一点,首先SSH进入服务器然后,在任何目录中(在下面的例子中,我将假设你的主目录,但任何目录都会这样做),运行:
passenger package-runtime
@H_301_15@
这似乎会进行大量的下载,配置和安装,但不要惊慌.所有这一切都是将乘客独立版本安装在名为passenger-standalone的子目录中.运行此命令后,您应该看到这样的文件结构(假设您在主目录中运行了命令):
+ /home/you
+ passenger-standalone
+ 3.0.11-....
Nginx-x.y.z.tar.gz
support.tar.gz
@H_301_15@
所以它只是一个有两个tar.gz文件的树(注意3.0.11 -…不是文字,但是会以该字符串开头 – 全名是系统相关的;类似于其中一个tar中的xyz .gz文件实际上是版本号).接下来,解压support.tar.gz,做这样的事情:
cd passenger-standalone/3.0.11-....
tar xzvvf support.tar.gz
@H_301_15@
这将解压缩到当前目录.在许多其他事情中,它将创建一个包含两个新文件的agents子目录:
+ /home/you
+ passenger-standalone
+ 3.0.11-....
+ agents
PassengerLoggingAgent
PassengerWatchdog
@H_301_15@
我们的想法是将这些代理文件复制到原始系统上,以修复系统版本中可能存在的任何损坏.但首先,适当地设置权限.继上面的命令停止后,运行:
cd agents
sudo chown root:rvm Passenger*
@H_301_15@
接下来,备份您的原始代理:
cd /usr/local/rvm/gems/ruby-1.9.3-p125/gems/passenger-3.0.11/agents
sudo cp PassengerLoggingAgent PassengerLoggingAgent.backup
sudo cp PassengerWatchdog PassengerWatchdog.backup
@H_301_15@
最后,在此处移动独立包中的新版本.
sudo mv /home/you/passenger-standalone/3.0.11-..../agents/Passenger* .
@H_301_15@
然后,重新启动Nginx.如果由于某种原因需要撤消此操作,只需还原备份副本并再次重新启动Nginx.
作为可选的清理步骤,您不再需要这些独立文件,因此您可以像这样删除它们:
rm -rf /home/you/passenger-standalone
@H_301_15@