之所以想使用solr来进行学习,很大一部分原因就是,solr能够在某种程度上提供RESTFUL相关的URL请求连接,可以把它理解为 以搜索引擎为基础的存储服务系统 ,由于他的搜索可以是针对URL的,那么他的扩展性就会很强,也不会对整个代码开发侵入性太强。
Lucene是一套提供搜索的类库,而Solr是建立在Lucene之上的一套全文检索的解决方案。你可以基于Lucene建立一套自己的搜索应用程序出来,也可以直接使用Solr、ElasticSearch等成熟的基于Lucene的搜索程序
源码地址:
项目执行效果(左边为本地搭建的solr环境进行的查询结果,右边是使用Eclipse来进行数据查询的结果,结果集匹配,测试结果正确):
1: 环境搭建: 本文使用的是solr5.1 和 tomcat7.x 版本,具体的项目整合例子如连接所示: :
2:环境整合完成后,是没有相应的cores的,显示 no cores available, 这时,需要本地进行core添加,这里不过多进行介绍,只是简单的进行文件夹的复制(注意由于是对文件夹的复制,所以需要编辑相应的两个xml文件)
3: 遇到报错:
org.apache.solr.client.solrj.impl.HttpSolrClient$RemoteSolrException: Error from server at http://127.0.0.1:8880/solr/collection1: Expected mime type application/octet-stream but got text/html.
这个错误就是因为没有上述所说的 collection1 节点的存在,只需要创建这个节点就可以了
org.apache.solr.client.solrj.impl.HttpSolrClient$RemoteSolrException: Error from server at http://127.0.0.1:8880/solr/collection1: ERROR: unknown field 'id'
这个错误就是,相对应的 solr_home\collection1\conf 这个节点下的conf文件夹下的 schema.xml 这个xml文件里面,并没有这个 filed ‘id’的配置,所以会报错,此时需要注意几个地方的 field 配置是需要匹配的。
--------------------------------------------分割线------------------20150515更新-------------------------
根据建议,上午找到了linux环境,在linux下搭建solr环境,很简单,直接解压缩 solr-5.1.0.tgz 文件,在linux环境下配置jdk环境,之后,进入到解压缩的solr-5.1.0文件夹,执行 bin/solr start -e cloud -noprompt
具体执行细节就不过多描述了,上述连接已有相关内容。