Ruby应用程序仅在Passenger“禁用”时才有效

时间:2010-11-06 20:21:59

标签: ruby apache2 sinatra passenger

我已经使用Apache和Passenger在Ubuntu服务器上部署了Sinatra应用程序。通过一些试验和错误,我意识到应用程序仅在乘客模块被禁用时才有效。

$ a2dismod passenger

Apache重启后,应用程序按预期运行。

如果我重新启用模块......

$ a2enmod passenger

......我在Apache重启时看到了这个警告:

[warn] module passenger_module is already loaded, skipping

,该应用程序停止工作。 Apache响应,提供vhost文档根目录的内容,但Passenger无法识别。

我很高兴我的应用程序有效,但我不确定如何解释启用/禁用乘客模块的相反效果。

2 个答案:

答案 0 :(得分:4)

我遇到了同样的问题:如果您使用此版本的Apache跟随乘客安装说明,您实际上可能会告诉Apache加载乘客两次。

在将3个着名行添加到Apache配置文件之前:

LoadModule passenger_module /usr/…/ext/apache2/mod_passenger.so
PassengerRoot /usr/local/rvm/gems/ruby-1.9.2-p290/gems/passenger-3.0.11
PassengerRuby /usr/local/rvm/wrappers/ruby-1.9.2-p290/ruby

检查配置文件apache2.conf中是否包含以下行:

# Include module configuration:
Include /etc/apache2/mods-enabled/*.load
Include /etc/apache2/mods-enabled/*.conf

如果这些行确实存在,则意味着在启动时,您的Apache服务器将包含/ mods中的每个* .conf和* .load文件 - 可用于/ mods-enabled,而不是加载它们。

因此,如果您在相关警告消息中运行,则表示您正在装载乘客模块两次!

您可以利用这个Apache功能转到/ mods-available,查找passenger.conf和passenger.load文件并编辑它们而不是apache2.conf。

'LoadModule passenger_module'行进入passenger.load,而另外2'PassengerRoot'和'PassengerRuby'行进入passenger.conf。

然后重新启动服务器,你会没事的。

有关此问题的更多信息,请访问:http://www.duccioarmenise.net/ruby-on-rails/warn-module-passenger_module-is-already-loaded/

答案 1 :(得分:0)

这很可能意味着您已经指定了两次“LoadModule passenger_module ...”。第一个条目不在passenger.conf中,第二个条目在passenger.conf中。