Solr服务的搭建
来源:互联网 发布:适合学生党的淘宝店铺 编辑:程序博客网 时间:2024/05/21 10:40
1. Solr服务的搭建
第一步:安装jdk、安装tomcat
第二步:解压solr压缩包。
第三步:将源码包中的dist/solr-4.10.3.war部署到tomcat下。
第四步:启动tomcat解压,解压缩war包。解压后,删除war包。
第五步:需要把源码包中example/lib/ext目录下的所有的jar包添加到solr/WEB-INF/lib下
第六步:创建solrhome。把源码包中example/solr文件夹复制一份作为solrhome。
第七步:需要修改solr工程下的web.xml,告诉solr服务solrhome的位置。
第八步:启动tomcat
2. 中文分词器的使用
分词器使用的是IKAnalyzer
使用方法:
第一步:把IKAnalyzer依赖的jar包添加到solr工程中。把分词器使用的扩展词典添加到classpath中,即classes目录下。
第二步:需要在Schema.xml中自定义一个FieldType。可以在FieldType中指定中文分析器。
<fieldType name="text_ik" class="solr.TextField"> <analyzer class="org.wltea.analyzer.lucene.IKAnalyzer"/></fieldType>
第三步:自定义域。指定Field的类型为自定义的FieldType。
第四步:重新启动tomcat
3. Solrj的使用
3.1 插入,删除和查询的测试
@Test public void testSolr() throws Exception{ SolrServer server = new HttpSolrServer("http://192.168.xx.xxx:8080/solr"); SolrInputDocument document = new SolrInputDocument(); document.addField("id", "testSolr"); document.addField("item_title","西瓜刀"); document.addField("item_sell_point","一劈两半"); server.add(document); server.commit(); } @Test public void testQuery() throws Exception{ SolrServer server = new HttpSolrServer("http://192.168.xx.xxx:8080/solr"); SolrQuery query = new SolrQuery("*:*"); QueryResponse response = server.query(query); SolrDocumentList results = response.getResults(); for (SolrDocument solrDocument : results) { System.out.println(solrDocument.get("id")); System.out.println(solrDocument.get("item_title")); System.out.println(solrDocument.get("item_sell_point")); } } @Test public void testDelete() throws Exception{ SolrServer server = new HttpSolrServer("http://192.168.xx.xxx:8080/solr"); server.deleteById("testSolr"); server.commit(); }
在实际应用中:
document ——对象
field字段 ——对象属性
3.2 高亮的使用
public SearchResult search(String queryString, int page, int rows) throws Exception { //创建查询条件 SolrQuery query = new SolrQuery(); //设置查询条件 query.setQuery(queryString); //设置分页条件 query.setStart((page-1)*rows); query.setRows(rows); //设置默认搜索域 query.set("df", "item_title"); //设置高亮 query.setHighlight(true); query.addHighlightField("item_title"); query.setHighlightSimplePre("<font class=\"skcolor_ljg\">"); query.setHighlightSimplePost("</font>"); //取高亮显示 Map<String, Map<String, List<String>>> highlighting = response.getHighlighting(); List<String> list = highlighting.get(solrDocument.get("id")).get("item_title"); String itemTitle = ""; if (list != null && list.size() > 0) { //取高亮后的结果 itemTitle = list.get(0); } else { itemTitle = (String) solrDocument.get("item_title"); } }
高亮类型的数据结构 : Map<String, Map<String, List<String>>>
阅读全文
0 0
- Solr服务的搭建
- Solr服务的搭建
- Solr服务的搭建
- Solr搜索服务的搭建(Liunx)
- 搜索引擎框架之Solr服务的搭建
- solr服务搭建
- solr服务搭建
- 一、solr服务搭建
- 初学Solr之tomcat搭建solr服务
- 搭建企业级搜索服务Solr
- linux服务器搭建solr服务
- zookeeper+solr搭建集群服务
- solr的环境搭建
- solr的搭建
- Solr集群的搭建
- solr服务器的搭建
- solr集群的搭建
- Solr的集群搭建
- Spring Cloud构建微服务架构(三)断路器
- 删除桌面hummingbird neighborhood图标
- Spring MVC之@RequestBody, @ResponseBody 作用
- (105)创建函数
- Mybatis的逆向工程
- Solr服务的搭建
- html中globalAlpha示例
- 【JSOI2011】bzoj4710 分特产
- 自勉
- IFrame的使用
- 信号量
- 在win7中chm打不开的多种解决方法
- 管理用户配置文件++查询用户配置文件+修改用户配置文件+删除用户配置文件
- LINUX发展趣文