`
wbj0110
  • 浏览: 1601160 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

8.分布式搜索elasticsearch java API ------使用More like this实现基于内容的推荐

阅读更多

基于内容的推荐通常是给定一篇文档信息,然后给用户推荐与该文档相识的文档。Lucene的api中有实现查询文章相似度的接口,叫MoreLikeThis。Elasticsearch封装了该接口,通过Elasticsearch的More like this查询接口,我们可以非常方便的实现基于内容的推荐。

先看一个查询请求的json例子:

 

[plain] view plaincopy
  1. {   
  2.     "more_like_this" : {   
  3.         "fields" : ["title", "content"],   
  4.         "like_text" : "text like this one",   
  5.     }   
  6. }  

其中:

 

fields是要匹配的字段,如果不填的话默认是_all字段

like_text是匹配的文本。

除此之外还可以添加下面条件来调节结果

percent_terms_to_match:匹配项(term)的百分比,默认是0.3

min_term_freq:一篇文档中一个词语至少出现次数,小于这个值的词将被忽略,默认是2

max_query_terms:一条查询语句中允许最多查询词语的个数,默认是25

stop_words:设置停止词,匹配时会忽略停止词

min_doc_freq:一个词语最少在多少篇文档中出现,小于这个值的词会将被忽略,默认是无限制

max_doc_freq:一个词语最多在多少篇文档中出现,大于这个值的词会将被忽略,默认是无限制

min_word_len:最小的词语长度,默认是0

max_word_len:最多的词语长度,默认无限制

boost_terms:设置词语权重,默认是1

boost:设置查询权重,默认是1

analyzer:设置使用的分词器,默认是使用该字段指定的分词器

 

下面介绍下如何用java api调用,一共有三种调用方式,不过本质上都是一样的,只不过是做了一些不同程度的封装。

 

[java] view plaincopy
  1. MoreLikeThisRequestBuilder mlt = new MoreLikeThisRequestBuilder(client, "indexName""indexType""id");  
  2. mlt.setField("title");//匹配的字段  
  3. SearchResponse response = client.moreLikeThis(mlt.request()).actionGet();  

这种是在查询与某个id的文档相似的文档。这个接口是直接在client那调用的,比较特殊。还有两种就是构造Query进行查询

 

 

[java] view plaincopy
  1. MoreLikeThisQueryBuilder query = QueryBuilders.moreLikeThisQuery();  
  2. query.boost(1.0f).likeText("xxx").minTermFreq(10);  

这里的boost、likeText方法完全和上面的参数对应的。下面这种就是把要匹配的字段作为参数传进来,参数和MoreLikeThisQueryBuilder是一样的。

 

 

[java] view plaincopy
  1. MoreLikeThisFieldQueryBuilder query = QueryBuilders.moreLikeThisFieldQuery("fieldNmae");  
分享到:
评论

相关推荐

    esapi-2.1.0.1.zip(esapi-2.1.0.1.jar)

    在“esapi-2.1.0.1.zip”这个压缩包中,核心文件“esapi-2.1.0.1.jar”是ESAPI库的实现,用于集成到Java项目中。此JAR文件包含了所有必要的类和资源,使开发者能够利用ESAPI提供的功能来强化应用程序的安全性。例如...

    elasticsearch-rest-high-level-client-6.8.3-API文档-中英对照版.zip

    赠送jar包:elasticsearch-rest-high-level-client-6.8.3.jar; 赠送原API文档:elasticsearch-rest-high-level-client-6.8.3-javadoc.jar; 赠送源代码:elasticsearch-rest-high-level-client-6.8.3-sources.jar;...

    elasticsearch-analysis-ik-7.16.3.zip

    Elasticsearch是一款基于Lucene的开源搜索和分析引擎,它提供了分布式、实时的搜索和分析能力,适用于日志分析、信息检索、监控等多种场景。Elasticsearch的核心功能包括全文搜索、聚合分析和实时数据存储。 二、...

    elasticsearch-rest-high-level-client-6.8.3-API文档-中文版.zip

    赠送jar包:elasticsearch-rest-high-level-client-6.8.3.jar; 赠送原API文档:elasticsearch-rest-high-level-client-6.8.3-javadoc.jar; 赠送源代码:elasticsearch-rest-high-level-client-6.8.3-sources.jar;...

    分布式搜索 elasticsearch 方案研究 - Java API

    本方案主要探讨如何利用 Java API 来与 Elasticsearch 进行交互,实现高效、稳定的分布式搜索功能。 ### 1. Elasticsearch 的核心特性 - **分布式架构**:Elasticsearch 采用分布式架构,能自动处理节点间的通信和...

    elasticsearch-rest-client-6.8.3-API文档-中文版.zip

    赠送jar包:elasticsearch-rest-client-6.8.3.jar; 赠送原API文档:elasticsearch-rest-client-6.8.3-javadoc.jar; 赠送源代码:elasticsearch-rest-client-6.8.3-sources.jar; 赠送Maven依赖信息文件:elastic...

    7.17.1系列Elasticsearch的elasticsearch-analysis-ik分词器

    中文分词:elasticsearch-analysis-ik 是基于最大正向匹配算法实现的中文分词器。它能够将中文文本按照合理的单词边界进行分割,并提供高质量的分词结果。 词库扩展性:elasticsearch-analysis-ik 采用了可扩展的...

    elasticsearch-rest-client-6.3.0-API文档-中英对照版.zip

    赠送jar包:elasticsearch-rest-client-6.3.0.jar; 赠送原API文档:elasticsearch-rest-client-6.3.0-javadoc.jar; 赠送源代码:elasticsearch-rest-client-6.3.0-sources.jar; 赠送Maven依赖信息文件:elastic...

    elasticsearch-7.17.7-windows-x86-64.zip

    Lucene是一款高效的、可扩展的全文检索库,Elasticsearch在其基础上构建了一套易于使用的API和分布式架构,使得开发者能够方便地在大规模数据集上实现复杂的搜索功能。 2. **分布式特性**:Elasticsearch设计时就...

    最新版 elasticsearch-analysis-ik-7.6.2.zip

    Elasticsearch 是一款高度可扩展的开源全文搜索引擎,它提供了实时、分布式的搜索和分析功能。在处理中文文档时,我们需要一个能够理解中文语言的分词器,这就是IK(Intelligent Chinese)分析器的用武之地。...

    最新版 elasticsearch-analysis-ik-7.13.4.zip

    Elasticsearch 是一个分布式、RESTful 风格的搜索和分析引擎,广泛应用于大数据的检索、分析场景。其强大的搜索功能得益于对各种数据类型的高效索引和查询支持。然而,对于非英文的文本,如中文,Elasticsearch 默认...

    elasticsearch-analysis-dynamic-synonym-7.12.1.zip

    标题 "elasticsearch-analysis-dynamic-synonym-7.12.1.zip" 指的是一个针对Elasticsearch的自定义同义词分析插件,该插件版本为7.12.1。Elasticsearch是一款流行的开源搜索引擎,用于处理、存储、搜索和分析大量...

    elasticsearch-6.3.0-API文档-中文版.zip

    赠送jar包:elasticsearch-6.3.0.jar; 赠送原API文档:elasticsearch-6.3.0-javadoc.jar; 赠送源代码:elasticsearch-6.3.0-sources.jar; 赠送Maven依赖信息文件:elasticsearch-6.3.0.pom; 包含翻译后的API文档...

    elasticsearch-analysis-ik-7.10.2.zip

    Elasticsearch(ES)作为一个开源的全文搜索引擎,因其强大的搜索功能和分布式特性而备受青睐。然而,对于中文这种复杂的语言,分词是搜索引擎理解文本的关键步骤。本文将详细介绍elasticsearch-analysis-ik-7.10.2...

    elasticsearch-6.2.4.tar.gz&kibana;-6.2.4-linux-x86_64..tar.gz

    Elasticsearch 6.2.4 和 Kibana 6.2.4 是两个非常重要的开源工具,它们在IT行业中,特别是在数据搜索、分析和可视化领域具有广泛的应用。这两个工具通常一起使用,构建一个强大的实时数据分析平台。 **Elastic...

    elasticsearch-6.2.4.tar.gz与kibana-6.2.4-linux-x86_64.tar.gz

    Elasticsearch 是一个分布式、RESTful 风格的搜索和数据分析引擎,而 Kibana 是一个数据可视化界面,可以将 Elasticsearch 中的数据以图形化的方式展示出来。 **Elasticsearch 6.2.4 知识点:** 1. **分布式架构**...

    elasticsearch-analysis-dynamic-synonym-7.0.0.zip

    "elasticsearch-analysis-dynamic-synonym-7.0.0.zip"是一个专为Elasticsearch设计的同义词插件,它的主要目的是在搜索过程中实现同义词的智能匹配,提高搜索的准确性和用户体验。 这个插件的独特之处在于它支持...

    elasticsearch-7.0.0-linux-x86_64.tar.gz

    Elasticsearch是一个强大的开源搜索引擎,广泛应用于大数据分析、日志聚合、实时搜索等多个领域。它的7.0.0版本是针对Linux操作系统优化的版本,具备高效、可扩展和易用的特点。在Linux环境下运行Elasticsearch,...

    elasticsearch-analysis-ik-7.10.0.zip下载

    总的来说,"elasticsearch-analysis-ik-7.10.0.zip"是Elasticsearch 7.10.0版的一个关键组件,它提升了系统处理中文文本的能力,通过优化的分词算法,使得搜索和分析中文内容变得更加准确和高效。对于那些处理大量...

Global site tag (gtag.js) - Google Analytics