我已经阅读了 Tire 文档,并且知道可以使用 Tire 创建索引并将对象导入 Elasticsearch,而无需使用 ActiveModel 包含。
我想让我的模型文件完全没有任何轮胎映射,而是单独实现它们。
到目前为止,我已经为我的 Member 模型创建了一个索引对象,如下所示:
class MemberIndexer
def initialize(member)
@member = member
end
def attributes
{
id: @member.id,
name: @member.full_name,
age: @member.age,
birthday: @member.birthday,
type: 'member'
}.to_json
end
def self.refresh_index
Tire.index 'members' do
delete
create mappings: {
member: {
properties: {
id: { type: 'integer' },
name: { type: 'string', boost: 5 },
age: { type: 'integer' },
birthday: { type: 'date' }
}
}
}
Member.find_in_batches do |members|
import members.map { |m| MemberIndexer.new(m).attributes }
end
end
end
end
这工作正常,索引已创建,我可以正确搜索。我缺少的是可以通过使用包含的回调Tire::Model::Callbacks
。是否可以使用轮胎更新索引中的单个记录而无需包含Tire::Model::Callbacks
在模型本身中?
例如,如果我更新 aMember
我希望能够手动更新成员索引中的相应项目。_id
在不知道该项目的情况下这可能吗?
我应该只使用 ActiveRecord id 搜索对象,然后在索引上使用更新方法吗?
更新: 我对 ES 不是使用实际的 ActiveRecord id 而是通过在 ES 中生成唯一 id 来索引成员这一事实感到困惑,即使我认为我在属性 json 中传递了一个 id。
当我将 ruby 哈希传递给import
方法时,id 字段得到了尊重,这个问题就消失了,因为我现在可以执行以下操作来更新索引记录:
Tire.index('member') do
store(MemberIndexer.new(@member).attributes)
end