翻译自 Apache Solr Reference Guide
solr提供了一个十分灵活,可拓展的搜索特性,当我们发送一个请求的时候,一个search query 被一个叫做requst handler处理,solr提供许多类型的request handler,有的是为了处理搜索请求的,还有一些设计成帮助管理请求的。
能够处理搜索请求的request handler叫做 query parser,不同的query parser支持不同的特性,solr包含一个标准的(LUCENE)和 拓展的DISMAX, 标准的能获得更好的准确性,DISMAX容错能力比较强。
一般而言,一个query parser的输入包含如下几个部分:
搜索字符串
一些参数微调field,或者剔除一些无关内容
一些参数控制responce的展现形式
这里有一个facet的概念,facet可以看成是一个目录,相当于组织数据的一个维度,在每一个目录中,facet constrain表示solr汇报相关的搜索结果,faceting方便用户查看比如在一些电影网站查看搜索结果。
solr的一个组件叫做 response writer组织返回的展现,比如XML response writer 和 JSON response writer.
相关性:
相关性是衡量一个结果对于这个用户的满足程度。
相关性的好坏取决于不同的环境,比如一个搜索服务,里面有天气的数据,一个大学的研究者试图研究气象的变化,一个农民倾向于知道什么时候是冬天的第一场雪,一个大学的学生更加倾向于什么时候放假,不同动机的用户自然相关性也会差别非常大。
如何全面的评判一个搜索的相关性,在不同的应用会有巨大差距,比如搜一张票据,和找一个蛋糕的配方会有巨大差距,所以在配置solr的时候,你得权衡好及时性和易用性。
关于相关性有两个概念:
Precision 准确率:返回的结果中相关结果的百分比
Recall 召回率:返回的相关结果占有所有相关结果的百分比
用好这两个概念,有可能量化相关性的结果,一个牛逼的系统能够有100%的召回率和100%的准确率,返回给系统的结果全是相关的,没有其他乱七八糟的,但是在真实的系统中,我们是在一定数量的结果中讨论这件事,比如说10个结果。
以下几点可以考虑在配置相关性中:
1. 使用用户的需求,比如要求易用,极快的响应速度,对信息准确性要求高
2. 考虑category的使用
3. 文档内在的相关性,一个官方的或者FAQ的结果应该排在上面。
4. 考虑文档的年龄,是否需要越新越靠前
相关推荐
solr中文解析器以及使用文档,配合blog使用
solr配置中文解析器和将数据导入solr索引库时所需的jar包
solr 应用全面解析,简单的应用,多实例,分布式索引分发 ,以数据库为数据源建立索引
主要介绍了python 动态迁移solr数据过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
很多初学者在对solr进行配置时,会出现很多问题。最近学习了solr,把自己的问题和解决办法分享给大家,希望有所帮助。
solr schema solrconfig 配置文件解析 solr schema solrconfig 配置文件解析
solr.warsolr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包solr.war包...
详细阐述Solr-search 源码级别过程
solr初学者很受用的!讲解了solr怎么创建索引的及其原理,以及查询
solr6.6.0源码
solr
solr
solr文档
详细的tomcat和solr的配置安装过程
solr-6.2.0 强大的分布式搜索引擎,包含各种详细例子及源码解析
solr manageschema 配置文件,增加了分词器后的配置文件
solr技术文solr技术文solr技术文
Solr定时更新Solr定时更新
如何使用solr搭建服务器