MongoMapper问题,堆栈级别太深

时间:2013-07-15 17:18:28

标签: mongodb sinatra mongomapper

首先想说的是我这么做了google这个主题并且无法找到适用于我自己用例的任何内容。

我有一个简单的小广告服务器。 Ad有一个模型,还有两个名为ImpressionClick的嵌入式模型,如下所示:

class Ad

  include MongoMapper::Document

  key :name, String
  key :image, String
  key :url, String

  has_many :clicks
  has_many :impressions

end

class Click

  include MongoMapper::EmbeddedDocument

  key :ip, String
  timestamps!

end

class Impression

  include MongoMapper::EmbeddedDocument

  key :ip, String
  timestamps!

end

这是我得到的错误:

SystemStackError - stack level too deep:
/home/deployer/.rbenv/versions/1.9.3-p125/lib/ruby/gems/1.9.1/gems/mongo_mapper-0.12.0/lib/mongo_mapper/plugins/keys.rb:194

以下是发生这种情况的区域:

@ad.impressions << Impression.new({:ip => request.ip})
@ad.save

现在,我的模型中没有任何回调,这就是很多人发生这种错误的原因。

任何人都有任何见解?

感谢。

1 个答案:

答案 0 :(得分:0)

我似乎已经找到了答案。 timestamps!是造成这种情况的原因。我在网上看到的其他例子与回调和ActiveSupport运行它们的方式有关。我只是没有意识到timestamps!算作一个。