共计 3643 个字符,预计需要花费 10 分钟才能阅读完成。
1.1 Solr是什么?
Solr 是 Apache 下的一个顶级开源项目,采用 Java 开发,它是基于 Lucene 的全文搜索服务器。Solr提供了比 Lucene 更为丰富的查询语言,同时实现了可配置、可扩展,并对索引、搜索性能进行了优化。
Solr是一个全文检索服务器,只需要进行配置就可以实现全文检索服务。
1.2 Solr的安装及配置
Solr的版本:4.10.3
1.2.1 安装步骤
需要把 solr 服务器安装到 linux 环境:
第一步:安装linux、jdk、tomcat。
[root@bogon ~]# ll
total 8044
-rw-r–r–. 1 root root 8234674 Oct 27 2013 apache-tomcat-7.0.47.tar.gz
[root@bogon ~]# tar -zxf apache-tomcat-7.0.47.tar.gz
[root@bogon ~]# ll
total 8048
drwxr-xr-x. 9 root root 4096 Sep 10 17:55 apache-tomcat-7.0.47
-rw-r–r–. 1 root root 8234674 Oct 27 2013 apache-tomcat-7.0.47.tar.gz
[root@bogon ~]# mkdir /usr/local/solr
[root@bogon ~]# cp apache-tomcat-7.0.47 /usr/local/solr/tomcat
cp: omitting directory `apache-tomcat-7.0.47′
[root@bogon ~]# cp apache-tomcat-7.0.47 /usr/local/solr/tomcat -r
[root@bogon ~]# cd /usr/local/solr/
[root@bogon solr]# ll
total 4
drwxr-xr-x. 9 root root 4096 Sep 10 17:56 tomcat
[root@bogon solr]#
第二步:把 solr 的压缩包上传到服务器。并解压。
第三步:把 /root/solr-4.10.3/dist/solr-4.10.3.war 包部署到 tomcat 下。并改名为solr.war
[root@bogon dist]# cp solr-4.10.3.war /usr/local/solr/tomcat/webapps/solr.war
第四步:解压 war 包。启动 tomcat 自动解压。关闭tomcat。删除solr.war.
第五步:把 /root/solr-4.10.3/example/lib/ext 目录下所有的 jar 包复制到 solr 工程中。
[root@bogon ext]# cp * /usr/local/solr/tomcat/webapps/solr/WEB-INF/lib/
第六步:创建 solrhome。Solrhome 是存放 solr 服务器所有配置文件的目录。
[root@bogon example]# pwd
/root/solr-4.10.3/example
[root@bogon example]# cp -r solr /usr/local/solr/solrhome
[root@bogon example]#
第七步:告诉 solr 服务器 solrhome 的位置。
需要修改 solr 工程的 web.xml 文件。
第八步:启动 tomcat
1.2.2 配置业务字段
1、在 solr 中默认是中文分析器,需要手工配置。配置一个 FieldType,在FieldType 中指定中文分析器。
2、Solr中的字段必须是先定义后使用。
1.2.2.1 中文分析器的配置
第一步:使用IK-Analyzer。把分析器的文件夹上传到服务器。
第二步:需要把分析器的 jar包添加到 solr 工程中。
[root@bogon IK Analyzer 2012FF_hf1]# cp IKAnalyzer2012FF_u1.jar /usr/local/solr/tomcat/webapps/solr/WEB-INF/lib/
[root@bogon IK Analyzer 2012FF_hf1]#
第三步:需要把 IKAnalyzer 需要的扩展词典及停用词词典、配置文件复制到 solr 工程的classpath。
/usr/local/solr/tomcat/webapps/solr/WEB-INF/classes
[root@bogon IK Analyzer 2012FF_hf1]# cp IKAnalyzer.cfg.xml ext_stopword.dic mydict.dic /usr/local/solr/tomcat/webapps/solr/WEB-INF/classes
[root@bogon IK Analyzer 2012FF_hf1]#
注意:扩展词典及停用词词典的字符集必须是 utf-8。不能使用windows 记事本编辑。
第四步:配置 fieldType。需要在solrhome/collection1/conf/schema.xml 中配置。
技巧:使用 vi、vim 跳转到文档开头gg。跳转到文档末尾:G
<fieldType name=”text_ik” > <analyzer /> </fieldType> |
1.2.2.2 业务字段配置
业务字段判断标准:
1、在搜索时是否需要在此字段上进行搜索。例如:商品名称、商品的卖点、商品的描述
2、后续的业务是否需要用到此字段。例如:商品id。
需要用到的字段:
1、商品id
2、商品title
3、卖点
4、价格
5、商品图片
6、商品分类名称
7、商品描述
Solr中的业务字段:
1、id——》商品id
其他的对应字段创建 solr 的字段。
<field name=”item_title” type=”text_ik” indexed=”true” stored=”true”/> <field name=”item_sell_point” type=”text_ik” indexed=”true” stored=”true”/> <field name=”item_price” type=”long” indexed=”true” stored=”true”/> <field name=”item_image” type=”string” indexed=”false” stored=”true” /> <field name=”item_category_name” type=”string” indexed=”true” stored=”true” /> <field name=”item_desc” type=”text_ik” indexed=”true” stored=”false” /> <field name=”item_keywords” type=”text_ik” indexed=”true” stored=”false” multiValued=”true”/> <copyField source=”item_title” dest=”item_keywords”/> <copyField source=”item_sell_point” dest=”item_keywords”/> <copyField source=”item_category_name” dest=”item_keywords”/> <copyField source=”item_desc” dest=”item_keywords”/> |
重新启动tomcat
1.3 维护索引库
添加:添加一个 json 格式的文件就可以。
修改:在 solr 中没有 update,只需要添加一个新的文档,要求文档id 和被修改文档的 id 一致。原理是先删除后添加。
删除:使用 xml 格式。
删除两种方法:
1、根据 id 删除:
<delete>
<id>test001</id>
</delete>
<commit/>
2、根据查询删除:
<delete>
<query>*:*</query>
</delete>
<commit/>
完成!
—————————————— 分割线 ——————————————
本文要用到的相关文件可从以下信息得到下载:
点击这个 http://www.linuxidc.com/Linux/2013-12/93755.htm 链接 关注 Linux 公社官方微信,关注后回复数字159305。即可得到网友的分享密码。
如果取消关注 Linux 公社公众号,即使再次关注,也将无法提供本服务!
链接: https://pan.baidu.com/s/1xjsi9VzSxEW-QcHlP_du2Q 密码:获得见上面的方法,地址失效请在下面留言。
—————————————— 分割线 ——————————————
: