es修改排序_ElasticSearch自定义排序(转载)

本文介绍了ElasticSearch中自定义排序的两种方式:基于Groovy脚本和基于Native脚本。Groovy脚本排序方便但速度较慢,而Native脚本排序速度快但部署较为复杂。建议在生产环境中使用Native脚本以提升性能。
摘要由CSDN通过智能技术生成

本文讨论ES的自定义排序的两种实现形式:基于groovy脚本的自定义排序和基于native script的自定义排序。

1. 基于Groovy脚本的自定义排序

ES的排序脚本必须放在config/scripts下面,ES能够自动发现这些脚本并提供对外使用, 例如编写脚本calculate-score.groovy

log(_score*2)+my_modifier

脚本中my_modifier是搜索请求中的参数,_score是ES计算得到的文档分数。发起搜索请求时指定用calculate-score排序

curl -XPOST localhost:9200/_search -d '{

"query": {

"function_score": {

"query": {

"match": {

"body": "foo"

}

},

"functions": [

{

"script_score": {

"lang": "groovy",

"script_file": "calculate-score",

"params": {

"my_modifier": 8

}

}

}

]

}

}}'

在上面的请求指定了my_modifier的值为8,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值