2011-05-23 202 views
3

我有这个工作在Ubuntu上很好,但我无法让它在Mac OS-X 10.6.7上工作。Apache与红宝石 - 宝石问题

我的Apache配置文件被编辑,以便它运行任何.rb文件。我正在使用的红宝石脚本有require 'rubygems'

在Ubuntu上,我在我的Apache配置文件中添加了SetEnv RUBYOPT rubygems,所以我甚至不需要使用require 'rubygems'。在我的Mac上,即使我需要rubygems,也无法加载宝石。

在IRB中,它加载的很好,我可以从命令行运行脚本OK。

我的脚本是在/库/ Web服务器/文件

Apache的错误日志说 -

 
[Mon May 23 18:56:40 2011] [error] [client ::1] /Library/Ruby/Gems/1.8/gems/dbi-0.4.5/lib/dbi/utils/date.rb:57: undefined method `deprecate' for DBI::Date:Class (NoMethodError) 
[Mon May 23 18:56:40 2011] [error] [client ::1] \tfrom /Library/Ruby/Site/1.8/rubygems/custom_require.rb:36:in `gem_original_require' 
[Mon May 23 18:56:40 2011] [error] [client ::1] \tfrom /Library/Ruby/Site/1.8/rubygems/custom_require.rb:36:in `require' 
[Mon May 23 18:56:40 2011] [error] [client ::1] \tfrom /Library/Ruby/Gems/1.8/gems/dbi-0.4.5/lib/dbi/utils.rb:56 
[Mon May 23 18:56:40 2011] [error] [client ::1] \tfrom /Library/Ruby/Site/1.8/rubygems/custom_require.rb:36:in `gem_original_require' 
[Mon May 23 18:56:40 2011] [error] [client ::1] \tfrom /Library/Ruby/Site/1.8/rubygems/custom_require.rb:36:in `require' 
[Mon May 23 18:56:40 2011] [error] [client ::1] \tfrom /Library/Ruby/Gems/1.8/gems/dbi-0.4.5/lib/dbi.rb:50 
[Mon May 23 18:56:40 2011] [error] [client ::1] \tfrom /Library/Ruby/Site/1.8/rubygems/custom_require.rb:58:in `gem_original_require' 
[Mon May 23 18:56:40 2011] [error] [client ::1] \tfrom /Library/Ruby/Site/1.8/rubygems/custom_require.rb:58:in `require' 
[Mon May 23 18:56:40 2011] [error] [client ::1] \tfrom /Library/WebServer/Documents/ruby_file.rb:6 

我认为增加require 'rubygems'意味着创业板的路径会被加载。任何人都知道为什么Apache无法加载宝石?

回答

0

我解决了这个问题,没有把require 'dbi'放到我的脚本中。使用require 'sqlite3'就足够了。