ruby on rails - Thinking Sphinx延迟增量索引-记录删除时索引不更新



我在使用thinking_sphinx的延迟delta时遇到了问题。这是模型:

Event
  has_many :subscriptions
  has_many :users, :through => :subscriptions
  ...
  define_index do
    indexes name
    indexes users(:id), :as => :user_id
    set_property :delta => :delayed
  ...
Subscription
  belongs_to :event
  belongs_to :user
User
  has_many :subscriptions
  has_many :events, :through => :subscriptions

当用户添加/删除订阅时,我通过订阅模型回调为所有相应的事件设置delta标志,如下所示:

after_save :set_events_delta_flag
after_destroy :set_events_delta_flag
def set_events_delta_flag
  Event.define_indexes
  sql = "UPDATE events SET delta = true FROM subscriptions"
  sql << " WHERE events.id = subscriptions.event_id AND (subscriptions.id = #{self.id})"
  Event.connection.update(sql)
  Event.index_delta
end

当用户添加订阅时,它工作正常:回调运行,然后ThinkingSphinx:: delta::DeltaJob运行并更新索引。但是,当用户删除订阅时,回调函数和DeltaJob运行,但索引似乎没有更新:

如果我这样做:

Event.search("". :with => {:user_id => XX}).search_count
添加订阅之前和之后,计数不会改变(它在添加订阅之前和之后都会改变)

这是预期的行为吗?我做错了什么?

Update:似乎Sphinx存储同一文档的两个副本(一个在核心索引中,一个在增量索引中)是问题的原因。

升级到Sphinx 2.0.3后,这个有两个索引的问题将会消失。这些指数将合并为单一指数。你可以试着升级一下

最新更新