`
wbj0110
  • 浏览: 1586298 次
  • 性别: 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");  
分享到:
评论

相关推荐

    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;...

    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;...

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

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

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

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

    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-analysis-ik-7.6.2.zip

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

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

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

    elasticsearch-analysis-ik-7.16.3.zip

    Elasticsearch是一款基于Lucene的开源搜索和分析引擎,它提供了分布式、实时的搜索和分析能力,适用于日志分析、信息检索、监控等多种场景。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-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-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...

    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-7.0.0-linux-x86_64.tar.gz

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

    ElasticSearch Java API 中文文档

    标题《ElasticSearch Java API 中文文档》表明本篇文档的主要内容是关于ElasticSearch的Java API的中文使用说明和相关知识点介绍。ElasticSearch是一个基于Lucene构建的开源搜索引擎,它提供了一个分布式、多用户...

    elasticsearch-analysis-ik-7.3.2.zip

    总的来说,"elasticsearch-analysis-ik-7.3.2"是ES进行中文文本处理的重要工具,通过合理的配置和使用,可以极大地提升中文搜索的准确性和效率。对于处理中文信息的ES应用,选择并正确使用IK分词器是提升服务质量的...

    elasticsearch-6.5.4.tar.gz elasticsearch-analysis-ik-6.5.4 (1).zip

    elasticsearch-6.5.4.tar.gz elasticsearch-analysis-ik-6.5.4 (1).zip es linux安装包及ik分词器插件 打包 elasticsearch-6.5.4.tar.gz elasticsearch-analysis-ik-6.5.4 (1).zip es linux安装包及ik分词器插件 ...

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

    Elasticsearch 是一个基于 Lucene 的开源全文搜索引擎,它提供了一个分布式、RESTful 风格的搜索和分析引擎,适用于各种数据检索和分析场景。它支持实时、高可用性,并且具有强大的数据处理和分析能力。 Elastic...

Global site tag (gtag.js) - Google Analytics