`
mxsfengg
  • 浏览: 208684 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

solr中竞价排名实现

    博客分类:
  • solr
阅读更多

        通常,lucene只返回与用户查询相关的文档,搜索的结果,跟lucene对文档评分有关。而在现实的查询中,我们有些时候需要为某些特定的文档指定它们在搜索结果中的位置。solr1.3 新推的组件QueryElevationComponent实现了这样的功能。

       

     如何在solrconfig.xml中配置 

        下面是一个在solrconfig.xml中配置的范例:

 

<searchComponent name="elevator" class="org.apache.solr.handler.component.QueryElevationComponent" >
    <str name="queryFieldType">string</str>
    <str name="config-file">elevate.xml</str>
  </searchComponent>

  <requestHandler name="/elevate" class="solr.SearchHandler">
    <lst name="defaults">
      <str name="echoParams">explicit</str>
    </lst>
    <arr name="last-components">
      <str>elevator</str>
    </arr>
  </requestHandler>

 

         queryFieldType

            这个参数指定了 输入的查询参数的类型。

           

          config-file

             这个参数指定elevation配置文件的路径。这个文件必须存在于以下两个位置:

  1.     ${instanceDir}/conf/${config-file}
  2.     ${dataDir}/${config-file} 

              如果配置文件在/conf/目录下,它只会在项目启动的时候被加载。如果配置文件实在data目录下,那么实例化IndexReader的时候会被加载。

              forceElevation

                 默认情况下,这个组件是尊重“sort”参数的,这个怎么说呢。举个例子,如果一个请求要求使用data排序,也就是进行sort,那么组件就会返回根据date排序的结果。我们将forceElevation设为true,那么结果集将首先返回我们指定的文档。

                 

         配置 elevate.xml

              怎么指定,指定什么样的内容。就是在elevate.xml文件中配置的。下面是一个elevate.xml文件的范例。

             

<elevate>

 <query text="AAA">
  <doc id="A" />
  <doc id="B" />
 </query>

 <query text="ipod">
  <doc id="A" />

  <!-- you can optionally exclude documents from a query result -->
  <doc id="B" exclude="true" />
 </query>

</elevate>

 

              在上面的这个配置文件中,当查询“AAA”的时候,会返回文档A,和文档B,然后就是其他的跟相关度有关的文档。

 

 

分享到:
评论
4 楼 13534608437 2015-10-21  
进价排名,每次往elevate.xml里面添加一条新的数据,是不是就得重新排序,好麻烦。
3 楼 fuanyu 2012-03-13  
兄弟,你测试通过不?还有forceElevation=true在哪里设置的?
2 楼 mxsfengg 2009-11-18  
你说的修改elevate.xml 是指什么呢,在运行时后的修改吗?

如果是重新启动服务器的话,reload是自动的。但是在运行时的时候,并没有提供这样的方法。

当然这是1.3版本的情况。1.4版本的还没有关注呢。
1 楼 jackdraw 2009-11-18  
不知道有没有试过修改过elevate.xml
如何在重启服务器的情况下reload

相关推荐

    solr实现电商自定义打分

    本篇文章将详细介绍如何利用Solr实现电商自定义打分机制。 首先,我们需要了解Solr的评分(Score)机制。Solr的默认评分是基于TF-IDF(词频-逆文档频率)算法的,它会根据查询词在文档中的出现频率和在整个索引中的...

    solr实现的搜索引擎

    在Solr中,数据存储的单位是Collection。通过Solr Admin UI或API可以创建、删除和管理Collections。每个Collection由一个或多个Shard组成,Shard又由多个Replica复制,确保高可用性和容错性。 4. **索引数据** ...

    solr实现京东搜索

    在Solr中,可以通过字段查询来实现这一功能。例如,为每个商品设置一个“category”字段,用户在搜索时可以选择特定分类,Solr会返回该分类下的所有商品。此外,Solr的 faceting 功能可用于展示不同分类下的商品数量...

    solr中文分词器

    在Solr中,分词器(Tokenizer)是分析器(Analyzer)的一部分,负责将输入的文本拆分成可被索引的基本单元——词(Token)。中文分词器的引入解决了英文分词相对简单,而中文以字为基本单位,需要特殊处理才能正确...

    solr中cache综述

    ### Solr中Cache综述及优化策略 #### 一、概述 Apache Solr是一个高性能、可伸缩的企业级搜索平台,它基于Lucene构建,在实际应用中为了提高查询效率和性能,内置了一系列缓存机制(Cache)。这些缓存机制不仅能够...

    solr中文文档.pdf

    ### SOLR中文文档知识点概述 ...这些知识点对于初学者来说是非常宝贵的资源,可以帮助他们快速上手SOLR并应用于实际项目中。此外,对于想要深入了解SOLR内部机制的开发者而言,掌握Lucene原理也是十分必要的。

    solr6.0中文分词

    总的来说,Solr 6.0 中文分词通过引入 IKAnalyzer 实现了对中文文本的有效处理,这对于搭建和优化面向中文用户的搜索系统至关重要。理解并掌握如何配置和使用分词器,可以极大地提升 Solr 系统在中文环境下的性能和...

    Solr5.4中文分词

    在Solr 5.4版本中,对中文分词的支持是通过特定的分词器实现的。本文将详细介绍如何在Solr 5.4中配置中文分词库。 首先,"Solr5.4中文分词"这个标题表明我们关注的是针对Solr 5.4的一个特定分词解决方案。这通常...

    ikanalyzer-solr中文分词包兼容solr7.5

    在Solr中集成ikanalyzer,可以提高中文搜索的性能,使得搜索结果更加准确,用户体验得到提升。 在实际应用中,安装ikanalyzer-solr分词包的步骤大致如下: 1. 将`ik-analyzer-solr5-5.x.jar`添加到Solr服务器的`...

    Solr实现电扇站内搜索

    Solr实现电扇站内搜索Solr实现电扇站内搜索Solr实现电扇站内搜索Solr实现电扇站内搜索

    solr中文分词高版本

    ikanalyzer是Java实现的一个开源中文分词器,它在Solr中常被用来处理中文文本。ikanalyzer-solr6.5及以上高版本很可能是ikanalyzer的特定版本,已经针对Solr 6.5及更高版本进行了优化和调整,确保能够正确地与这些新...

    solr(中文分词器)集群

    在Solr中使用IK分词器,是为了更好地处理中文文本的分词。IK分词器(Intelligent Chinese Analyzer for Solr)是针对Solr优化的中文分词工具,它支持多种分词模式,包括精确模式、全模式、关键词模式等,以满足不同...

    solr 中文分词

    要在 Solr 中使用 IK Analyzer,首先需要将其添加到 Solr 的类路径中,然后在 Solr 的 schema.xml 或 managed-schema 文件中配置字段类型(fieldType),指定使用 IK Analyzer。同时,可以设置自定义词典路径,以...

    solr4.7中文企业开发参考文档

    7. **处理多种数据格式**:Solr支持多种数据源,包括JSON、XML、CSV等,可以通过DataImportHandler(DIH)从关系型数据库中导入数据,实现对非结构化数据的检索。 8. **更新和优化索引**:Solr提供了实时索引更新和...

    支持solr5.5 solr6.0中IK分词需要的资料

    在Solr中,分词器(Tokenizer)是文本分析的重要组成部分,它负责将输入的原始文本拆分成可搜索的独立单元——词语。IK分词器(Intelligent Chinese Analyzer for Solr,简称IK)是一款针对中文的高效分词工具,专为...

    solr 5.x 和 6.x 最新中文分词器

    下面将详细介绍Solr中的中文分词器及其相关知识。 一、Solr中文分词器概述 在处理中文文档时,由于中文句子没有明显的分隔符,如英文的空格,因此需要使用分词器进行预处理。Solr支持多种中文分词器,如IK Analyzer...

    solr中文教程

    Apache Solr 是一款开源的企业级搜索服务器,基于 Java 实现,并使用 HTTP 和 XML 作为通信协议,便于集成到各种环境中。Solr 提供了强大的全文检索功能,支持高亮显示搜索结果,具备动态集群能力,可以与多种数据库...

    solr中文分词器ik-analyzer-solr7.x

    在Solr中,分词器是核心组件之一,负责对输入的中文文本进行分词处理,生成可以被索引和查询的关键词。IK Analyzer作为Solr的插件,可以实现以下功能: 1. **中文分词**:通过内置的中文词典,将输入的中文句子拆分...

    solr中的mmesg4j中文分词器安装

    ### Solr中的MMSeg4J中文分词器安装与配置详解 #### 一、MMSeg4J简介 MMSeg4J是一款高效的Java实现的中文分词工具包,它基于统计和规则混合的方法来处理中文文本的分词问题。在搜索引擎如Solr中,通过集成MMSeg4J...

Global site tag (gtag.js) - Google Analytics