我正在尝试在Elasticsearch中使用渗滤功能。它很好用,但是开箱即用,没有处理单数/复数等的问题。有关该主题的文档非常少,所以我想知道是否有人进行过此工作以及需要什么设置。目前,我没有索引文档,因为我没有搜索它们,只是将它们传递给过滤器以触发通知。
最佳答案
您可以使用percolate API来针对渗滤器测试文档,而无需编制索引。但是,percolate
API需要doc的index
和type
。这样一来,它便知道如何定义(或映射)文档中的每个字段。
分析器属于索引,并且映射/类型定义中的字段可以使用全局定义的分析器,也可以使用为索引定义的定制分析器。
例如,我们可以使用全局定义的分析器为索引test
定义映射,键入test
,如下所示:
curl -XPUT 'http://127.0.0.1:9200/test/?pretty=1' -d '
{
"mappings" : {
"test" : {
"properties" : {
"title" : {
"type" : "string",
"analyzer" : "english"
}
}
}
}
}
'
或者,您可以设置一个仅属于
test
索引的自定义分析器:curl -XPUT 'http://127.0.0.1:9200/test/?pretty=1' -d '
{
"mappings" : {
"test" : {
"properties" : {
"title" : {
"type" : "string",
"analyzer" : "my_english"
}
}
}
},
"settings" : {
"analysis" : {
"analyzer" : {
"my_english" : {
"stopwords" : [],
"type" : "english"
}
}
}
}
}
'
现在我们可以创建我们的过滤器,指定它属于哪个索引:
curl -XPUT 'http://127.0.0.1:9200/_percolator/test/english?pretty=1' -d '
{
"query" : {
"match" : {
"title" : "singular"
}
}
}
'
并使用
percolate
API进行测试,再次指定索引和类型:curl -XGET 'http://127.0.0.1:9200/test/test/_percolate?pretty=1' -d '
{
"doc" : {
"title" : "singulars"
}
}
'
# {
# "ok" : true,
# "matches" : [
# "english"
# ]
# }
关于elasticsearch - elasticsearch渗滤器茎干,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/14844082/