亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Elasticsearch算分優(yōu)化方案之rescore_query示例詳解

 更新時間:2023年08月23日 15:54:47   作者:醉魚  
這篇文章主要為大家介紹了Elasticsearch算分優(yōu)化方案之rescore_query示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

簡介

今天來說一說Elasticsearch 的重新評分,即在檢索出來一次結(jié)果的基礎(chǔ)上在進行檢索提升數(shù)據(jù)排序效果,但是僅對查詢或者post_filter階段返回的前多少條進行二次查詢。在每個分片上進行二次檢索的文檔數(shù)量時可以通過window_size 控制的,該參數(shù)默認(rèn)10。

默認(rèn)情況下,原來的查詢語句與二次查詢的份數(shù)將線性組合以生成文檔的最終得分_score,原始查詢語句的權(quán)重通過query_weight控制,重新二次查詢的權(quán)重通過rescore_query_weight控制,他們默認(rèn)都是1。

在Elasticsearch中,rescore_query是一種用于改進搜索結(jié)果排序的查詢。它可以在原始查詢結(jié)果的基礎(chǔ)上重新計算得分,并重新排序搜索結(jié)果。

rescore_query通常用于在搜索過程的后期階段對搜索結(jié)果進行優(yōu)化。它可以根據(jù)特定的需求和業(yè)務(wù)規(guī)則,對原始查詢結(jié)果進行二次排序,以提高最相關(guān)的文檔的排名。

rescore_query可以在分布式搜索中非常有用,因為它僅在原始查詢的結(jié)果上執(zhí)行計算,而不需要重新執(zhí)行整個查詢過程。這可以提高搜索速度并減輕系統(tǒng)負(fù)載。

通過使用rescore_query,可以根據(jù)不同的評分算法、過濾器或其他上下文信息,對搜索結(jié)果進行個性化的定制排序。它可以根據(jù)文檔的屬性、時間戳、地理位置等進行排序,以獲得更加準(zhǔn)確和有用的搜索結(jié)果。

總而言之,rescore_query是一種用于改進搜索結(jié)果排序的查詢,可以根據(jù)不同的規(guī)則和需求重新計算得分并重新排序搜索結(jié)果,以提高搜索準(zhǔn)確性和實用性。

實戰(zhàn)

搭建ES環(huán)境

version: '3.8'
services:
  cerebro:
    image: lmenezes/cerebro:0.8.3
    container_name: cerebro
    ports:
     - "9000:9000"
    command:
     - -Dhosts.0.host=http://eshot:9200
    networks:
     - elastic
  kibana:
    image: docker.elastic.co/kibana/kibana:8.1.3
    container_name: kibana
    environment:
      - I18N_LOCALE=zh-CN
      - XPACK_GRAPH_ENABLED=true
      - TIMELION_ENABLED=true
      - XPACK_MONITORING_COLLECTION_ENABLED="true"
      - ELASTICSEARCH_HOSTS=http://eshot:9200
      - server.publicBaseUrl=http://192.168.160.234:5601
    ports:
      - "5601:5601"
    networks:
      - elastic
  eshot:
    image: elasticsearch:8.1.3
    container_name: eshot
    environment:
      - node.name=eshot
      - cluster.name=es-docker-cluster
      - discovery.seed_hosts=eshot,eswarm,escold
      - cluster.initial_master_nodes=eshot,eswarm,escold
      - bootstrap.memory_lock=true
      - "ES_JAVA_OPTS=-Xms512m -Xmx512m"
      - xpack.security.enabled=false
      - node.attr.node_type=hot
    ulimits:
      memlock:
        soft: -1
        hard: -1
    volumes:
      - D:\zuiyuftp\docker\es8.1\eshot\data:/usr/share/elasticsearch/data
      - D:\zuiyuftp\docker\es8.1\eshot\logs:/usr/share/elasticsearch/logs
      - D:\zuiyuftp\docker\es8.1\eshot\plugins:/usr/share/elasticsearch/plugins
    ports:
      - 9200:9200
    networks:
      - elastic
  eswarm:
    image: elasticsearch:8.1.3
    container_name: eswarm
    environment:
      - node.name=eswarm
      - cluster.name=es-docker-cluster
      - discovery.seed_hosts=eshot,eswarm,escold
      - cluster.initial_master_nodes=eshot,eswarm,escold
      - bootstrap.memory_lock=true
      - "ES_JAVA_OPTS=-Xms512m -Xmx512m"
      - xpack.security.enabled=false
      - node.attr.node_type=warm
    ulimits:
      memlock:
        soft: -1
        hard: -1
    volumes:
      - D:\zuiyuftp\docker\es8.1\eswarm\data:/usr/share/elasticsearch/data
      - D:\zuiyuftp\docker\es8.1\eswarm\logs:/usr/share/elasticsearch/logs
      - D:\zuiyuftp\docker\es8.1\eshot\plugins:/usr/share/elasticsearch/plugins
    networks:
      - elastic
  escold:
    image: elasticsearch:8.1.3
    container_name: escold
    environment:
      - node.name=escold
      - cluster.name=es-docker-cluster
      - discovery.seed_hosts=eshot,eswarm,escold
      - cluster.initial_master_nodes=eshot,eswarm,escold
      - bootstrap.memory_lock=true
      - "ES_JAVA_OPTS=-Xms512m -Xmx512m"
      - xpack.security.enabled=false
      - node.attr.node_type=cold
    ulimits:
      memlock:
        soft: -1
        hard: -1
    volumes:
      - D:\zuiyuftp\docker\es8.1\escold\data:/usr/share/elasticsearch/data
      - D:\zuiyuftp\docker\es8.1\escold\logs:/usr/share/elasticsearch/logs
      - D:\zuiyuftp\docker\es8.1\eshot\plugins:/usr/share/elasticsearch/plugins
    networks:
      - elastic
# volumes:
#   eshotdata:
#     driver: local
#   eswarmdata:
#     driver: local
#   escolddata:
#     driver: local
networks:
  elastic:
    driver: bridge

創(chuàng)建索引

PUT /zfc-doc-000006
{
  "mappings": {
    "properties": {
      "title":{
        "type": "text",
        "analyzer": "ik_max_word"
      },
      "content": {
        "type": "text",
        "analyzer": "ik_max_word"
      }
    }
  }
}

添加測試數(shù)據(jù)

PUT _bulk
{"index":{"_index":"zfc-doc-000006","_id":"1"}}
{"title":"ES實戰(zhàn)","content":"ES的實戰(zhàn)操作,實戰(zhàn)要領(lǐng),實戰(zhàn)經(jīng)驗"}
{"index":{"_index":"zfc-doc-000006","_id":"2"}}
{"title":"MySQL實戰(zhàn)","content":"MySQL的實戰(zhàn)操作"}
{"index":{"_index":"zfc-doc-000006","_id":"3"}}
{"title":"MySQL","content":"MySQL一定要會"}

檢索驗證

首先我們還是正常檢索一下content字段中包含實戰(zhàn)的文檔

GET zfc-doc-000006/_search
{
  "query": {
    "match": {
      "content": "實戰(zhàn)"
    }
  }
}

按照我們的預(yù)期,因為文檔1中包含實戰(zhàn)3次出現(xiàn),所以titleES實戰(zhàn)的排名靠前,可以看到文檔1的算分為0.6,位列第一,輸出結(jié)果如下

"max_score" : 0.667102,
    "hits" : [
      {
        "_index" : "zfc-doc-000006",
        "_id" : "1",
        "_score" : 0.667102,
        "_source" : {
          "title" : "ES實戰(zhàn)",
          "content" : "ES的實戰(zhàn)操作,實戰(zhàn)要領(lǐng),實戰(zhàn)經(jīng)驗"
        }
      },
      {
        "_index" : "zfc-doc-000006",
        "_id" : "2",
        "_score" : 0.5442147,
        "_source" : {
          "title" : "MySQL實戰(zhàn)",
          "content" : "MySQL的實戰(zhàn)操作"
        }
      }
    ]

然后對檢索出來的實戰(zhàn)的文檔中,進行重新算分排序,包含MySQL的排名在前,增加算分

GET zfc-doc-000006/_search
{
  "query": {
    "match": {
      "content": "實戰(zhàn)"
    }
  },
  "rescore": {
    "query": {
      "rescore_query":{
        "match":{
          "title":"MySQL"
        }
      },
      "query_weight" : 0.7,
      "rescore_query_weight" : 1.2
    },
    "window_size": 50
  }
}

上述查詢語句的意思就是查詢content字段中包含”實戰(zhàn)“的文檔,權(quán)重為0.7。并對文檔中titleMySQL的文檔增加評分,權(quán)重為1.2,window_size50,表示取分片結(jié)果的前50進行重新算分

響應(yīng)結(jié)果如下,可以看到titleMySQL實戰(zhàn)的評分已經(jīng)變?yōu)?code>0.9,遠遠的超過了titleES實戰(zhàn)的文檔

"hits" : [
      {
        "_index" : "zfc-doc-000006",
        "_id" : "2",
        "_score" : 0.9022989,
        "_source" : {
          "title" : "MySQL實戰(zhàn)",
          "content" : "MySQL的實戰(zhàn)操作"
        }
      },
      {
        "_index" : "zfc-doc-000006",
        "_id" : "1",
        "_score" : 0.46697137,
        "_source" : {
          "title" : "ES實戰(zhàn)",
          "content" : "ES的實戰(zhàn)操作,實戰(zhàn)要領(lǐng),實戰(zhàn)經(jīng)驗"
        }
      }
    ]

總結(jié)

通過rescore_query我們可以對檢索結(jié)果進行二次評分,增加自己更復(fù)雜的評分邏輯,提供更準(zhǔn)確的結(jié)果排序,但是相應(yīng)的也會增加查詢的計算成本與響應(yīng)時間。

《一篇文章讓你學(xué)會Elasticsearch中的查詢》一文中,我們學(xué)習(xí)了修改算分的幾種方式,本文學(xué)習(xí)了如何在檢索結(jié)果返回之后對檢索結(jié)果進行更精細(xì)的二次評分排序。后面推出一篇專門修改算分的文章,以此來實現(xiàn)工作中的修改算分的需求。

以上就是Elasticsearch算分優(yōu)化方案之rescore_query示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Elasticsearch算分rescore_query的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 通俗易懂的Java常見限流算法具體實現(xiàn)

    通俗易懂的Java常見限流算法具體實現(xiàn)

    這篇文章主要介紹了Java常見限流算法具體實現(xiàn)的相關(guān)資料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的實現(xiàn)原理和具體步驟,并比較了它們的優(yōu)點和缺點,需要的朋友可以參考下
    2025-02-02
  • 深入解析SpringBoot自動配置原理

    深入解析SpringBoot自動配置原理

    這篇文章主要介紹了深入解析SpringBoot自動配置原理,SpringBoot?的一大好處就是:大大簡化了?Spring?和其他框架的整合配置,為了簡化配置文件使開發(fā)者更專注于業(yè)務(wù)編碼,可以使用?SpringBoot?來進行?Web?開發(fā),需要的朋友可以參考下
    2023-11-11
  • Spring Session的使用示例

    Spring Session的使用示例

    最近團隊一個項目需要使用Session,之前沒有在實際項目中使用過Spring-Session,這里記錄一下使用的過程
    2021-06-06
  • Fluent Mybatis如何做到代碼邏輯和sql邏輯的合一

    Fluent Mybatis如何做到代碼邏輯和sql邏輯的合一

    對比原生Mybatis, Mybatis Plus或者其他框架,F(xiàn)luentMybatis提供了哪些便利呢?很多朋友對這一問題不是很清楚,今天小編給大家?guī)硪黄坛剃P(guān)于Fluent Mybatis如何做到代碼邏輯和sql邏輯的合一,一起看看吧
    2021-08-08
  • Spring Security基于json登錄實現(xiàn)過程詳解

    Spring Security基于json登錄實現(xiàn)過程詳解

    這篇文章主要介紹了Spring Security基于json登錄實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-08-08
  • 使用Java發(fā)送郵件到QQ郵箱的完整指南

    使用Java發(fā)送郵件到QQ郵箱的完整指南

    在現(xiàn)代軟件開發(fā)中,郵件發(fā)送功能是一個常見的需求,無論是用戶注冊驗證、密碼重置,還是系統(tǒng)通知,郵件都是一種重要的通信方式,本文將詳細(xì)介紹如何使用Java編寫程序,實現(xiàn)發(fā)送郵件到QQ郵箱的功能,需要的朋友可以參考下
    2025-03-03
  • spring data jpa 創(chuàng)建方法名進行簡單查詢方式

    spring data jpa 創(chuàng)建方法名進行簡單查詢方式

    這篇文章主要介紹了spring data jpa 創(chuàng)建方法名進行簡單查詢方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • SpringBoot集成WebSocket的兩種方式(JDK內(nèi)置版和Spring封裝版)

    SpringBoot集成WebSocket的兩種方式(JDK內(nèi)置版和Spring封裝版)

    這篇文章主要介紹了SpringBoot集成WebSocket的兩種方式,這兩種方式為JDK內(nèi)置版和Spring封裝版,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • Mybatis防止sql注入的實例

    Mybatis防止sql注入的實例

    本文通過實例給大家介紹了Mybatis防止sql注入的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-06-06
  • SpringBoot訪問外部文件及默認(rèn)路由問題

    SpringBoot訪問外部文件及默認(rèn)路由問題

    這篇文章主要介紹了SpringBoot訪問外部文件及默認(rèn)路由問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11

最新評論