基于内容的推荐通常是给定一篇文档信息,然后给用户推荐与该文档相识的文档。Lucene的api中有实现查询文章相似度的接口,叫MoreLikeThis。Elasticsearch封装了该接口,通过Elasticsearch的More like this查询接口,我们可以非常方便的实现基于内容的推荐。
先看一个查询请求的json例子:
- {
- "more_like_this" : {
- "fields" : ["title", "content"],
- "like_text" : "text like this one",
- }
- }
其中:
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调用,一共有三种调用方式,不过本质上都是一样的,只不过是做了一些不同程度的封装。
- MoreLikeThisRequestBuilder mlt = new MoreLikeThisRequestBuilder(client, "indexName", "indexType", "id");
- mlt.setField("title");//匹配的字段
- SearchResponse response = client.moreLikeThis(mlt.request()).actionGet();
这种是在查询与某个id的文档相似的文档。这个接口是直接在client那调用的,比较特殊。还有两种就是构造Query进行查询
- MoreLikeThisQueryBuilder query = QueryBuilders.moreLikeThisQuery();
- query.boost(1.0f).likeText("xxx").minTermFreq(10);
这里的boost、likeText方法完全和上面的参数对应的。下面这种就是把要匹配的字段作为参数传进来,参数和MoreLikeThisQueryBuilder是一样的。
- MoreLikeThisFieldQueryBuilder query = QueryBuilders.moreLikeThisFieldQuery("fieldNmae");
相关推荐
Elasticsearch是一款基于Lucene的开源搜索和分析引擎,它提供了分布式、实时的搜索和分析能力,适用于日志分析、信息检索、监控等多种场景。Elasticsearch的核心功能包括全文搜索、聚合分析和实时数据存储。 二、...
赠送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;...
赠送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;...
本方案主要探讨如何利用 Java API 来与 Elasticsearch 进行交互,实现高效、稳定的分布式搜索功能。 ### 1. Elasticsearch 的核心特性 - **分布式架构**:Elasticsearch 采用分布式架构,能自动处理节点间的通信和...
中文分词:elasticsearch-analysis-ik 是基于最大正向匹配算法实现的中文分词器。它能够将中文文本按照合理的单词边界进行分割,并提供高质量的分词结果。 词库扩展性:elasticsearch-analysis-ik 采用了可扩展的...
赠送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...
赠送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(ES)作为一个开源的全文搜索引擎,因其强大的搜索功能和分布式特性而备受青睐。然而,对于中文这种复杂的语言,分词是搜索引擎理解文本的关键步骤。本文将详细介绍elasticsearch-analysis-ik-7.10.2...
Lucene是一款高效的、可扩展的全文检索库,Elasticsearch在其基础上构建了一套易于使用的API和分布式架构,使得开发者能够方便地在大规模数据集上实现复杂的搜索功能。 2. **分布式特性**:Elasticsearch设计时就...
Elasticsearch 是一个分布式、RESTful 风格的搜索和分析引擎,广泛应用于大数据的检索、分析场景。其强大的搜索功能得益于对各种数据类型的高效索引和查询支持。然而,对于非英文的文本,如中文,Elasticsearch 默认...
标题 "elasticsearch-analysis-dynamic-synonym-7.12.1.zip" 指的是一个针对Elasticsearch的自定义同义词分析插件,该插件版本为7.12.1。Elasticsearch是一款流行的开源搜索引擎,用于处理、存储、搜索和分析大量...
赠送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 是一款高度可扩展的开源全文搜索引擎,它提供了实时、分布式的搜索和分析功能。在处理中文文档时,我们需要一个能够理解中文语言的分词器,这就是IK(Intelligent Chinese)分析器的用武之地。...
Elasticsearch 6.2.4 和 Kibana 6.2.4 是两个非常重要的开源工具,它们在IT行业中,特别是在数据搜索、分析和可视化领域具有广泛的应用。这两个工具通常一起使用,构建一个强大的实时数据分析平台。 **Elastic...
Elasticsearch 是一个分布式、RESTful 风格的搜索和数据分析引擎,而 Kibana 是一个数据可视化界面,可以将 Elasticsearch 中的数据以图形化的方式展示出来。 **Elasticsearch 6.2.4 知识点:** 1. **分布式架构**...
Elasticsearch 是一个基于 Lucene 的开源全文搜索引擎,它提供了一个分布式、RESTful 风格的搜索和分析引擎,适用于各种数据检索和分析场景。它支持实时、高可用性,并且具有强大的数据处理和分析能力。 Elastic...
Elasticsearch是一个强大的开源搜索引擎,广泛应用于大数据分析、日志聚合、实时搜索等多个领域。它的7.0.0版本是针对Linux操作系统优化的版本,具备高效、可扩展和易用的特点。在Linux环境下运行Elasticsearch,...
Elasticsearch(ES)是一款功能强大的全文搜索引擎,广泛应用于数据检索、数据分析等领域。为了提高搜索的准确性和便利性,Elasticsearch提供了丰富的分析插件,其中"elasticsearch-analysis-dynamic-synonym-7.2.0...
Elasticsearch是一个强大的开源搜索引擎,广泛应用于大数据分析和实时数据检索。它基于Lucene库,提供了分布式、RESTful风格的搜索和分析引擎服务。在Linux系统中,Elasticsearch能够轻松部署并与其他开源技术,如...