solrj-solr Guide 4.7
solrj是一个很容易使java应用程序和solr进行交互的一个API,solrj隐藏了很多连接Solr的细节,允许你的应用程序使用简单的高级方法和solr互动交流.
solrj的核心就是 org.apache.solr.client.solrj包,下面包含了5个主要类.通过创建一个SolrServer开始,这个SolrServer就是你索要使用的solr实例,然后发出SolrRequests或者是SolrQuerys,最后返回SolrResponses.
SolrServer是一个抽象类,所以为了连接远程主机的Solr实例,一般创建一个HttpSolrServer实例.这个实例主要用于通过http和Solr服务进行交互.
String urlString = "http://localhost:8983/solr";
SolrServer solr = new HttpSolrServer(urlString);
创建一个SolrServer并不会使网络连接,当你在执行查询或者是其他操作时,才会连接网络,如果URL字符串不正确的话,会抛出一个MalformedURLException异常.
一旦创建完SolrServer之后,就可以调用query(),add(),method()的方法.
构建和运行SolrJ应用程序
1. 添加to be in the classpath. solr-solrj-4.x.x.jar类.
2.dist/solrj-lib下的类库需要加载.
3.使用Maven的话,在pom.xml中添加:
<dependency>
<groupId>org.apache.solr</groupId>
<artifactId>solr-solrj</artifactId>
<version>4.x.0</version>
</dependency>
如果担心solrJ扩展了客户端应用程序的大小,可以使用一个代码模糊处理工具像 ProGuard来删除你不使用的API.
设置XMLResponseParser
solrj使用的是二进制格式,而不是xml格式作为它的默认格式.较早版本的solr的用户通过设置解析器XMLResponseParser来使用XML格式操作.
server.setParser(new XMLResponseParser());
执行查询
使用query()方法获取solr的搜索结果.你需要传递一个描述查询信息的SolrQuery对象,然后返回一个QueryResponse对象.
SolrQuery有很多方法,很容易的添加参数用于选择请求处理器(handler),并且发送参数给handler.这里是一个很简单的例子,使用默认
请求处理器,设置q参数:
SolrQuery parameters = new SolrQuery();
parameters.set("q", mQueryString);
选择不同的请求处理器,只需要设置qt参数:
parameters.set("qt", "/spellCheckCompRH");
一旦设置完成SolrQuery,使用query()来提交:
QueryResponse response = solr.query(parameters);
这个客户端生成了一个网络连接,并发送了query查询信息,solr处理这个查询信息,然后response响应,并返回一个QueryResponse.
QueryResponse就是一个满足查询参数的文档结果集合.可以通过getResults()方法直接得到检索结果文档,也可以调用其他方法来获取高亮和分面的信息.
SolrDocumentList list = response.getResults();
索引文档
其他的操作也很简单,对于索引文档来说,你只需要创建一个SolrInputDocument对象,并通过SolrServer的add()方法传递数据,然后调用
commit()方法即可.
String urlString = "http://localhost:8983/solr";
SolrServer solr = new HttpSolrServer(urlString);
SolrInputDocument document = new SolrInputDocument();
document.addField("id", "552199");
document.addField("name", "Gouda cheese wheel");
document.addField("price", "49.99");
UpdateResponse response = solr.add(document);
// Remember to commit your changes!
solr.commit();
用XML或者二进制格式上传内容(content)
SolrJ允许您在XML和二进制格式上传内容而不是默认的XML格式.solrj可以使用以下使用二进制格式上传,同样采用相同的格式获取结果.
server.setRequestWriter(new BinaryRequestWriter());
使用ConcurrentUpdateSolrServer
当实现Java应用程序时,这将会一次性加载大量的文档,ConcurrentUpdateSolrServer 是一个HttpSolrServer的替代类,ConcurrentUpdateSolrServer使用Buffer缓冲添加所有的文档,并将其写入到开放HttpSolrServer中.这个类是线程安全的,虽然任意的SolrServer请求都能使用这个实现来完成,但是只推荐使用ConcurrrentUpdateSolrServer做/update请求.
EmbeddedSolrServer
这种嵌入方式在大多数情况下都是不推荐使用的,并且它支持相当有限的solr功能,尤其是不能在SolrCloud或者Index Replication.EmbeddedSolrServer的存在主要是帮助更容易的测试.
对于EmbeddedSolrServer的使用,可以参考Solrj的Junit单元测试,org.apache.solr.client.solrj.embedded包.
相关主题
索引和基本数据操作(待发布)
本节内容翻译自:Apache Solr Reference Guide 4.7,不当之处,请指正! 谢谢.
solrj-solr Guide 4.7的更多相关文章
- Solr系列四:Solr(solrj 、索引API 、 结构化数据导入)
一.SolrJ介绍 1. SolrJ是什么? Solr提供的用于JAVA应用中访问solr服务API的客户端jar.在我们的应用中引入solrj: <dependency> <gro ...
- Solr JAVA客户端SolrJ 4.9使用示例教程
http://my.oschina.net/cloudcoder/blog/305024 简介 SolrJ是操作Solr的JAVA客户端,它提供了增加.修改.删除.查询Solr索引的JAVA接口.So ...
- 使用solrj操作solr索引库,solr是lucene服务器
客户端开发 Solrj 客户端开发 Solrj Solr是搭建好的lucene服务器 当然不可能完全满足一般的业务需求 可能 要针对各种的架构和业务调整 这里就需要用到Solrj了 Solrj是Sol ...
- 【Solr专题之九】SolrJ教程
一.SolrJ基础 1.相关资料 API:http://lucene.apache.org/solr/4_9_0/solr-solrj/ apache_solr_ref_guide_4.9.pdf:C ...
- 【Solr专题之九】SolrJ教程 分类: H4_SOLR/LUCENCE 2014-07-28 14:31 2351人阅读 评论(0) 收藏
一.SolrJ基础 1.相关资料 API:http://lucene.apache.org/solr/4_9_0/solr-solrj/ apache_solr_ref_guide_4.9.pdf:C ...
- Solr+Tomcat+zookeeper部署实战
一 .安装solr 环境说明:centos 7.3,solr 6.6,zookeeper3.4,Tomcat8.5,jdk1.8 zookeeper的部署请参考:http://www.cnblogs. ...
- 全文搜索引擎——Solr
1.部署solr a.下载并解压Solr b.导入项目(独立项目): 将解压后的 server\solr-webapp 下的 webapp文件夹 拷贝到tomcat的webapps下,并重命名为 so ...
- Solr7.4.0的API(Solrj)操作及项目中的使用
一.SolrJ的概念 solr单机版服务搭建:https://www.cnblogs.com/frankdeng/p/9615253.html solr集群版服务搭建:https://www.cnbl ...
- Solr7.4.0的API(Solrj)操作
一.SolrJ的概念 solr单机版服务搭建:https://www.cnblogs.com/frankdeng/p/9615253.html solr集群版服务搭建:https://www.cnbl ...
- solr 高亮显示
官网:https://lucene.apache.org/solr/guide/6_6/highlighting.html#Highlighting-TheUnifiedHighlighter 前言 ...
随机推荐
- 【转】B树、B-树、B+树、B*树
B树 即二叉搜索树: 1.所有非叶子结点至多拥有两个儿子(Left和Right): 2.所有结点存储一个关键字: 3.非叶子结点的左指针指向小于其关键字的子树,右指针指向大于其关键字的子树: 如: B ...
- 安装glibc2.7
参考链接http://fhqdddddd.blog.163.com/blog/static/18699154201401722649441/ /lib/libc.so.6: version `glib ...
- UVaLive 6602 Counting Lattice Squares (找规律)
题意:给定一个n*m的矩阵,问你里面有几面积为奇数的正方形. 析:首先能知道的是,大的矩阵是包括小的矩阵的,而且面积为奇数,我们只要考虑恰好在边界上的正方形即可,画几个看看就知道了,如果是3*3的有3 ...
- js 设置回车事件
document.onkeydown=function(event){ var e = event || window.event || arguments.callee.caller.argumen ...
- 100个直接可以拿来用的JavaScript实用功能代码片段(转载)
把平时网站上常用的一些实用功能代码片段通通收集起来,方面网友们学习使用,利用好的话可以加快网友们的开发速度,提高工作效率. 目录如下: 1.原生JavaScript实现字符串长度截取2.原生JavaS ...
- Oracle的体系结构
前言 这个章节主要想说的是Oracle的体系结构,这个也是理论强些.还有一些比较理论的知识点(比如表空间啊),就暂时先不写了,下一章节开始进入Oracle的操作阶段,比如表的查询啊.插入以及重点是和S ...
- 通过ajax获得json数据后格式的转换
在有些情况下获取到的json数据可能是string类型的,需要把其格式化为json对象才方便解析. a)原生js通过ajax获取到的json 此时返回的数据默认是string型的,所以需要用eval( ...
- CloudStack4.2 二级镜像存储测试
//添加二级存储{ "addimagestoreresponse": { "imagestore": { "id": "2dda4 ...
- HTML定位(滚动条、元素,视口)定位
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- JQuery 弹出层,始终显示在屏幕正中间
1.让层始终显示在屏幕正中间: 样式代码: .model{ position: absolute; z-index: 1003; width:320px; height:320px; text-ali ...