1、Solr是什么?
Solr 是Apache下的一个顶级开源项目,采用Java开发,它是基于Lucene的全文搜索服务器。Solr提供了比Lucene更为丰富的查询语言,同时实现了可配置、可扩展,并对索引、搜索性能进行了优化。
Solr是一个全文检索服务器,只需要进行配置就可以实现全文检索服务。
2、solr的安装
1、安装jdk1.7
具体参考我的文章:Centos7下安装jdk1.7。这里不再赘述。
2、安装tomcat
(1)上传并解压tomcat7安装包:
tar -zxf apache-tomcat-7.0.47.tar.gz
(2)创建solr文件夹,并将解压后的tomcat复制过去:
[root@bogon ~]# mkdir /usr/local/solr
[root@bogon ~]# cp apache-tomcat-7.0.47 /usr/local/solr/tomcat -r
3、安装solr
(1)上传并解压solr安装包:
tar -zxf solr-4.10.3.tgz.tgz
(2)把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
(3)解压war包。启动tomcat自动解压。关闭tomcat。删除solr.war.
启动命令:sh bin/startup.sh
停止命令:sh bin/shutdown.sh
(4)把solr-4.10.3/example/lib/ext 目录下所有的jar包复制到solr工程中:
[root@bogon ext]# cp * /usr/local/solr/tomcat/webapps/solr/WEB-INF/lib/
(5)在solr下创建solrhome。Solrhome是存放solr服务器所有配置文件的目录:
[root@bogon example]# pwd
/root/solr-4.10.3/example
[root@bogon example]# cp -r solr /usr/local/solr/solrhome
(6)告诉solr服务器solrhome的位置。需要修改solr工程的web.xml文件。
(7)启动tomcat,测试solr。
3、Solr的使用
import org.apache.solr.client.solrj.SolrQuery;
import org.apache.solr.client.solrj.SolrServer;
import org.apache.solr.client.solrj.impl.HttpSolrServer;
import org.apache.solr.client.solrj.response.QueryResponse;
import org.apache.solr.common.SolrDocument;
import org.apache.solr.common.SolrDocumentList;
import org.apache.solr.common.SolrInputDocument;
import org.junit.Test;
public class TestSolrj {
/**
* 在solr中增加数据
* @throws Exception
*/
@Test
public void addDocument() throws Exception{
SolrServer solrServer = new HttpSolrServer("http://10.10.1.146:8080/solr");
SolrInputDocument document = new SolrInputDocument();
document.addField("id","test01");
document.addField("item_title","测试商品");
document.addField("item_price","100");
solrServer.add(document);
solrServer.commit();
}
/**
* 在solr中修改数据(id相同,即可修改相应数据)
* @throws Exception
*/
@Test
public void updateDocument() throws Exception{
SolrServer solrServer = new HttpSolrServer("http://10.10.1.146:8080/solr");
SolrInputDocument document = new SolrInputDocument();
document.addField("id","test01");
document.addField("item_title","测试商品2");
document.addField("item_price","200");
solrServer.add(document);
solrServer.commit();
}
/**
* 在solr中删除数据
* @throws Exception
*/
@Test
public void deleteDocument() throws Exception{
SolrServer solrServer = new HttpSolrServer("http://10.10.1.146:8080/solr");
//根据id删除
solrServer.deleteById("test01");
//根据查询条件删除
//solrServer.deleteByQuery("*:*");
solrServer.commit();
}
/**
* 在solr中查询数据
* @throws Exception
*/
@Test
public void queryDocument() throws Exception {
SolrServer solrServer = new HttpSolrServer("http://10.10.1.146:8080/solr");
//创建一个查询对象
SolrQuery query = new SolrQuery();
//设置查询条件
query.setQuery("*:*");
query.setStart(20);
query.setRows(50);
//执行查询
QueryResponse response = solrServer.query(query);
//取查询结果
SolrDocumentList solrDocumentList = response.getResults();
System.out.println("共查询到记录:" + solrDocumentList.getNumFound());
for (SolrDocument solrDocument : solrDocumentList) {
System.out.println(solrDocument.get("id"));
System.out.println(solrDocument.get("item_title"));
System.out.println(solrDocument.get("item_price"));
System.out.println(solrDocument.get("item_image"));
}
}
}