淘淘商城项目我爱编程

Solr的安装和使用

2018-05-22  本文已影响17人  WebGiser

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文件。

image.png
(7)启动tomcat,测试solr。
image.png

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"));

        }
    }
}
上一篇下一篇

猜你喜欢

热点阅读