美文网首页
linux环境下的solr服务搭建及soloj的使用

linux环境下的solr服务搭建及soloj的使用

作者: MrRobot_ | 来源:发表于2019-02-19 16:26 被阅读10次

    Solr服务搭建

    Solr是java开发。
    需要安装jdk
    安装环境Linux
    需要安装Tomcat

    搭建步骤

    第一步:把solr 的压缩包上传到Linux系统
    第二步:解压solr。
    第三步:安装Tomcat,解压缩即可。
    第四步:把solr部署到Tomcat下。
    第五步:解压缩war包。启动Tomcat解压。
    第六步:把/root/solr-4.10.3/example/lib/ext目录下的所有的jar包,添加到solr工程中。
    [root@localhost ext]# pwd
    /root/solr-4.10.3/example/lib/ext
    [root@localhost ext]# cp * /usr/local/solr/tomcat/webapps/solr/WEB-INF/lib/
    第七步:创建一个solrhome。/example/solr目录就是一个solrhome。复制此目录到/usr/local/solr/solrhome
    [root@localhost example]# pwd
    /root/solr-4.10.3/example
    [root@localhost example]# cp -r solr /usr/local/solr/solrhome
    [root@localhost example]#
    第八步:关联solr及solrhome。需要修改solr工程的web.xml文件。


    第九步:启动Tomcat
    http://192.168.25.138:8080/solr
    和windows下的配置完全一样

    配置业务域

    schema.xml中定义:
    1、商品Id
    2、商品标题
    3、商品卖点
    4、商品价格
    5、商品图片
    6、分类名称

    创建对应的业务域,需要制定中文分析器。

    创建步骤:
    第一步:把中文分析器添加到工程中。
    1、把IKAnalyzer2012FF_u1.jar添加到solr工程的lib目录下


    2、把扩展词典、配置文件放到solr工程的WEB-INF/classes目录下。


    第二步:配置一个FieldType,制定使用IKAnalyzer
    修改schema.xml文件
    修改Solr的schema.xml文件,添加FieldType:

    <fieldType name="text_ik" class="solr.TextField">
      <analyzer class="org.wltea.analyzer.lucene.IKAnalyzer"/>
    </fieldType>
    

    第三步:配置业务域,type制定使用自定义的FieldType。
    设置业务系统Field

    <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_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"/>
    
    image.png

    第四步:重启tomcat


    分词效果测试

    使用solrJ管理索引库

    添加文档:

    第一步:把solrJ的jar包添加到工程中。
    第二步:创建一个SolrServer,使用HttpSolrServer创建对象。
    第三步:创建一个文档对象SolrInputDocument对象。
    第四步:向文档中添加域。必须有id域,域的名称必须在schema.xml中定义。
    第五步:把文档添加到索引库中。
    第六步:提交。

    @Test
        public void addDocument() throws Exception {
            // 第一步:把solrJ的jar包添加到工程中。
            // 第二步:创建一个SolrServer,使用HttpSolrServer创建对象。
            SolrServer solrServer = new HttpSolrServer("http://192.168.25.154:8080/solr");
            // 第三步:创建一个文档对象SolrInputDocument对象。
            SolrInputDocument document = new SolrInputDocument();
            // 第四步:向文档中添加域。必须有id域,域的名称必须在schema.xml中定义。
            document.addField("id", "test001");
            document.addField("item_title", "测试商品");
            document.addField("item_price", "199");
            // 第五步:把文档添加到索引库中。
            solrServer.add(document);
            // 第六步:提交。
            solrServer.commit();
        }
    
    添加成功

    删除文档:

    @Test
        public void deleteDocument() throws Exception {
            SolrServer solrServer = new HttpSolrServer("http://192.168.25.138:8080/solr/collection1");
            //删除文档
            //solrServer.deleteById("doc01");
            solrServer.deleteByQuery("id:doc01");
            //提交
            solrServer.commit();
        }
    
    删除成功

    查询文档(简单查询):
    查询步骤:
    第一步:创建一个SolrServer对象
    第二步:创建一个SolrQuery对象。
    第三步:向SolrQuery中添加查询条件、过滤条件。。。
    第四步:执行查询。得到一个Response对象。
    第五步:取查询结果。
    第六步:遍历结果并打印。

    @Test
        public void queryIndex() throws Exception {
            //创建一个SolrServer对象。
            SolrServer solrServer = new HttpSolrServer("http://192.168.25.138:8080/solr/collection1");
            //创建一个SolrQuery对象。
            SolrQuery query = new SolrQuery();
            //设置查询条件。
            //query.setQuery("*:*");
            query.set("q", "*:*");
            //执行查询,QueryResponse对象。
            QueryResponse queryResponse = solrServer.query(query);
            //取文档列表。取查询结果的总记录数
            SolrDocumentList solrDocumentList = queryResponse.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_sell_point"));
                System.out.println(solrDocument.get("item_price"));
                System.out.println(solrDocument.get("item_image"));
                System.out.println(solrDocument.get("item_category_name"));
            }
        }
    

    查询文档(复杂查询)

    @Test
        public void queryIndexFuza() throws Exception {
            SolrServer solrServer = new HttpSolrServer("http://192.168.25.138:8080/solr/collection1");
            //创建一个查询对象
            SolrQuery query = new SolrQuery();
            //查询条件
            query.setQuery("手机");
            query.setStart(0);
            query.setRows(20);
            query.set("df", "item_title");
            query.setHighlight(true);
            query.addHighlightField("item_title");
            query.setHighlightSimplePre("<em>");
            query.setHighlightSimplePost("</em>");
            //执行查询
            QueryResponse queryResponse = solrServer.query(query);
            //取文档列表。取查询结果的总记录数
            SolrDocumentList solrDocumentList = queryResponse.getResults();
            System.out.println("查询结果总记录数:" + solrDocumentList.getNumFound());
            //遍历文档列表,从取域的内容。
            Map<String, Map<String, List<String>>> highlighting = queryResponse.getHighlighting();
            for (SolrDocument solrDocument : solrDocumentList) {
                System.out.println(solrDocument.get("id"));
                //取高亮显示
                List<String> list = highlighting.get(solrDocument.get("id")).get("item_title");
                String title = "";
                if (list !=null && list.size() > 0 ) {
                    title = list.get(0);
                } else {
                    title = (String) solrDocument.get("item_title");
                }
                System.out.println(title);
                System.out.println(solrDocument.get("item_sell_point"));
                System.out.println(solrDocument.get("item_price"));
                System.out.println(solrDocument.get("item_image"));
                System.out.println(solrDocument.get("item_category_name"));
            }
        }
    

    相关文章

      网友评论

          本文标题:linux环境下的solr服务搭建及soloj的使用

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