为什么我收到错误“db_name必须是字符串或符号”?

时间:2011-08-13 18:07:46

标签: mongodb sinatra mongoid yaml

快速版(适用于那些熟悉Mongoid& Sinatra的人):如果 Psyche / {{ 3}} YAML解析问题,为什么 else 在尝试使用Mongoid连接到MongoDB数据库时可能会出现此错误? (或者也许那个问题,在这种情况下,我如何修复我的mongoid.yml文件,发布在下面?)


更详细(原始)版本

我有一个Sinatra应用程序通过Mongoid与MongoDB数据库进行交互:

configure do
    Mongoid.load!('config/mongoid.yml')
end

我的mongoid.yml文件如下所示:

development:
    host: localhost
    database: project_development

test:
    host: localhost
    database: project_test

production:
    uri: <%= ENV['MONGOLAB_URI'] %>

每当我尝试以某种方式与数据库交互时,我都会收到错误 db_name必须是字符串或符号

现在,我已经在Google上找到了很多的相关信息;但我能找到的一切似乎表明问题与Ruby有关,现在使用Psyche YAML解析器而不是旧的Syck解析器。我不认为这在我的案例中实际上是相关的,因为据我所知,上述YAML应该可以完全解析。

(但值得的是,我已经尝试使用YAML::ENGINE.yamler= 'syck'技巧,但无济于事。我收到了完全相同的错误消息。)

当我将配置更改为:

Mongoid.configure do |config|
    name = "project_development"
    host = "localhost"
    config.master = Mongo::Connection.new.db(name)
end

...然后一切正常。所以我知道MongoDB正在我的机器上工作。特别是当我使用YAML文件时出现问题。

那是什么给了什么?

2 个答案:

答案 0 :(得分:10)

确保ENV['RACK_ENV']设置正确,因为如果找不到Mongoid.load!Rails.env会使用{{1}}。

答案 1 :(得分:0)

我遇到了与rails相同的问题并以这种方式解决了它:

问题在于Mongoid和MongodbLogger对mongoid.yml结构的不同期望。 简短:只需在上一级添加数据库:

development:
  sessions:
    default:
      database: apollo_development                       <<<< for the rest
      hosts:
        - localhost:27017
      options:
        consistency: :strong
  database: apollo_development                           <<<<main level for logger
    .... more stuff for the logger

优点是您可以将数据库用于数据,将另一个数据库用于记录器。 技术上有两个使用yml的独立系统:logger和MongoId。