我有一个消息体系结构,消息本身嵌套在一个级别 . 每条消息(父)都可以有多个子节点,每条消息(子节点)都属于父节点 .

parent_id 属性标识消息是父/子,还是其子节点 .

请在下面找到我的模型和相应的关联 .

Class AbstractMessage

  belongs_to :parent, class_name: 'AbstractMessage', inverse_of: :children    

  scope :with_a_parent, where("parent_id IS NOT NULL")

  has_many :children, class_name: 'AbstractMessage', foreign_key: :parent_id, 
  include: [:children],
  conditions: "id IN (#{AbstractMessage.with_a_parent.select(:id).to_sql})",
  inverse_of: :parent

end

在这种情况下,我面临着一个带有以下查询的无限递归循环 .

AbstractMessage.where(id: message_root_ids).includes(:children).index_by(&:id)

奇怪的是 this issue happens only when it is being called via web server (passenger/nginx) . 从控制台触发时相同的查询返回正确的结果 .

有关此问题发生原因的任何帮助 . 也是为什么它只通过Web服务器发生 .

在此先感谢您的帮助 .