通过 Painless 脚本控制 elasticsearch 搜索结果的评分

通过 Painless 脚本控制 elasticsearch 搜索结果的评分


为了控制搜索结果的相关度,elasticsearch 提供了多种方式,通过脚本实现自定义评分逻辑是终极方式。脚本返回一个评分值,该值再与原_score再进行加法等运算。脚本编写很简单,我们跟随一个例子(基于5.5版本)来看看如何通过脚本实现自定义排序。

创建 user_info索引,只有一个 name 字段,并且不分词:

写入测试数据

对于搜索结果,理想的顺序是:

高波
高大山
高峰玉成
李高峰
闫高峰
安建高

执行搜索:

返回结果如下:

得分都是1.0,我们期望的返回顺序与两个原则有关:
1.关键词出现的位置越靠前,排序应该越靠前
2.字段值约短,说明匹配度越高,排序应该越靠前

下面我们通过脚本来实现自定义评分。

elasticsearch 支持多种脚本语言,经历各版本演变后,从5.0开始实现了自己专用的语言:Painless。Groovy已弃用,这次示例使用Painless实现,Painless是内置支持的。脚本内容可以通过多种途径传给 es,包括 rest 接口,或者放到 config/scripts目录等,默认开启情况如下:

script.inline: false
script.stored: false
script.file: true

通过本地文件的方式放置到 config/scripts 目录默认开启。脚本目录中放置的任何文件将在节点启动后自动编译。默认每60秒扫描一次,间隔时间通过 resource.reload.interval设置。编写脚本文件,命名为:user_info_score.painless

获取文档值:doc[‘name’].value
实现比较简单,根据位置和相似度分别计算评分,将结果乘不同权重再相加。

再次查询:

function_score 查询 是用来控制评分过程的终极武器,它允许为每个与主查询匹配的文档应用一个函数, 以达到改变甚至完全替换原始查询评分 _score 的目的。

script_score 用自定义脚本完全控制评分计算,实现所需逻辑

lang 指定脚本语言

inline, stored, file 指定脚本的源。 这里使用文件方式,脚本名称为:user_info_score 注意这里要去掉.painless扩展名

params 指定作为变量传递到脚本中的任何命名参数。

boost_mode 新计算的分数与_score的结合方式,取值可以是:

multiply 相乘(默认)
replace 替换_score
sum 相加
avg 取平均值
max 取最大值
min 取最小值

搜索结果:

Painless语法参考链接:
https://www.elastic.co/guide/en/elasticsearch/painless/5.5/painless-syntax.html
https://www.elastic.co/guide/en/elasticsearch/painless/5.5/index.html
https://www.elastic.co/guide/en/elasticsearch/painless/5.5/painless-api-reference.html

其他:

https://www.elastic.co/guide/en/elasticsearch/reference/current/query-dsl-function-score-query.html
https://www.elastic.co/guide/en/elasticsearch/reference/5.5/modules-scripting-using.html#modules-scripting-file-scripts

(转载请注明作者和出处 easyice.cn ,请勿用于任何商业用途)

1 Star2 Stars3 Stars4 Stars5 Stars (2 人打了分, 平均分: 5.00 )
Loading...

2 thoughts on “通过 Painless 脚本控制 elasticsearch 搜索结果的评分

发表评论

邮箱地址不会被公开。 必填项已用*标注