客户需求:使用自定义扩展的similarity class,让关键字出现的频率对搜索得分的影响为0,即关键字出现的频率不影响得分。
1.编写SolrSimilarity类,并打包SolrSimilarity-1.0-SNAPSHOT.jar
package org.apache.solr.similarity;
import org.apache.lucene.search.similarities.ClassicSimilarity;
//此处只需要tf全部返回1即可保证频率对得分无影响
public class SolrSimilarity extends ClassicSimilarity {
@Override
public float tf(float freq) {
return 1.0f;
}
}
2.在对应的配置集的managed-schema中配置
<similarity class="org.apache.solr.similarity.SolrSimilarity">
</similarity>
3.在对应的配置集的solrconfig.xml中配置
<lib dir="/your_lib_dir/" regex="SolrSimilarity*.jar" />
4.将配置集更新到zk
5.重启solr服务使修改生效(其实只要保证重启当前collection所分布的节点即可,但是为了之后使用此配置集创建索引不引发其他未知问题,此时选择重启整个服务,让这个自定义扩展类在每个solrserver都生效)