solr安装、使用、配置中文分词器

solr 是基于lucene搜索库的一个搜索引擎框架,它将lucene进行了封装,实现了企业级应用框架。有提供完整集群及索引库优化方案。

solr可以独立运行,运行在Jetty、Tomcat等这些Servlet容器中,Solr 索引的实现方法很简单,用 POST 方法向Solr 服务器发送一个描述 Field 及其内容的 XML 文档,Solr根据xml文档添加、删除、更新索引 。Solr 搜索只需要发送HTTP GET 请求,然后对 Solr返回Xml、json等格式的查询结果进行解析,组织页面布局。Solr不提供构建UI的功能,Solr提供了一个管理界面,通过管理界面可以查询Solr的配置和运行情况。

  1. 安装
    下载地址:http://archive.apache.org/dist/lucene/solr/
    (服务器在国外,下载会比较慢。可以使用solr6.1.0下载

  2. 下载完成解压压缩包
    这里写图片描述

  3. 启动solr
    这里写图片描述
    这里写图片描述

  4. 访问solr后台管理界面
    http://127.0.0.1:8983/solr/#/
    这里写图片描述
  5. 创建core(可以理解为mysql中的数据库,即一个服务可以有多个库)
solr create -c gxl_core

这里写图片描述
这里写图片描述
6. 进入你刚创建的core,测试分词
这里写图片描述
由于solr自带的分词器无法将中文根据语义分词,需要引入中文分词器IKAnalyzer

a. 将ik的jar放入solr-6.1.0\server\solr-webapp\webapp\WEB-INF\lib目录下
b. 修改solr-6.1.0\server\solr\corename\conf\managed-schema.xml文件,在schema标签中添加如下代码

<!-- IKAnalyzer-->
  <fieldType name="text_ik" class="solr.TextField" autoGeneratePhraseQueries="false">
            <analyzer class="org.wltea.analyzer.lucene.IKAnalyzer" type="index">
            </analyzer>
            <analyzer class="org.wltea.analyzer.lucene.IKAnalyzer" type="query">
            </analyzer>
    </fieldType>

c. 重启solr

solr restart -p 8983

经过以上操作后,再看下分词效果
这里写图片描述

嗯,满意了~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Solr 9.2.0默认使用Lucene 8.6.0,其自带了一个中文分词SmartChineseAnalyzer。 在Solr配置中文分词的步骤如下: 1. 在solrconfig.xml中配置分词 在schema.xml中定义field时,需要指定使用的分词,例如: ``` <field name="text" type="text_cn" indexed="true" stored="true"/> ``` 在solrconfig.xml中,需要配置text_cn类型的分词,例如: ``` <fieldType name="text_cn" class="solr.TextField"> <analyzer type="index"> <tokenizer class="org.apache.lucene.analysis.cn.smart.SmartChineseTokenizerFactory"/> </analyzer> <analyzer type="query"> <tokenizer class="org.apache.lucene.analysis.cn.smart.SmartChineseTokenizerFactory"/> </analyzer> </fieldType> ``` 其中,tokenizer指定了使用的分词,这里使用的是SmartChineseTokenizerFactory,它是SmartChineseAnalyzer的底层分词。 2. 配置停用词 在solrconfig.xml中,可以配置停用词,在分词时将停用词过滤掉,例如: ``` <filter class="solr.StopFilterFactory" words="stopwords.txt" ignoreCase="true" /> ``` 其中,words指定了停用词文件的路径,可以自己定义。 3. 配置同义词 在solrconfig.xml中,可以配置同义词,在分词时将同义词替换掉,例如: ``` <filter class="solr.SynonymFilterFactory" synonyms="synonyms.txt" ignoreCase="true" expand="true" /> ``` 其中,synonyms指定了同义词文件的路径,可以自己定义。expand指定是否将同义词扩展,例如"中国, 中国人, 中国人民",如果expand=true,则搜索"中国"时会将其扩展为"中国 中国人 中国人民"。 以上就是在Solr 9.2.0中配置中文分词的基本步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值