Solr的安装和使用

作者: WebGiser | 来源:发表于2018-05-22 16:12 被阅读17次

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

    相关文章

      网友评论

        本文标题:Solr的安装和使用

        本文链接:https://www.haomeiwen.com/subject/oixkjftx.html