http://www.iteye.com/job/topic/1133159
Lucene 的索引体系是一个写独占,读共享的结构,这意味着,我们在使用多线程进行添加索引时,性能并不会得到明显的提升,所以任何时刻只能有一个线程对索引进行写 入操作,而保障这个操作的安全性则是来自于,Lucene独特的锁机制(写入操作进行时,我们可以在Lucene的索引根目录里看到一个命名为 write.lock的锁文件),如果同一时刻有多个不同IndexWriter对索引进行写入操作,那么将会引发锁重叠异常,所以Lucene的特殊的 索引结构,决定了其只能使用一个IndexWriter对索引进行添加操作。
即使是限定Lucen只能使用一个线程进行写入操作,Lucene的写入性能也是非常高效的,特别是在Lucene4.x之后,更是优异,我们可以根据自己服务器的硬件环境,来调优一些参数,利用上批处理的特性,可以大大提升写入性能。
前面说过,Lucene写入时只能用一个线程操作,那么假如我们想使用多线程写入来提速可以吗?
答案是肯定的,虽然Lucene限定只能用一个线程写入,但是这个限制仅仅指的是对一个索引文件的限制,我们可以采取一种折中的方式,利用多个线
程写入多个索引文件夹目录,最后在对这几个索引文件合并,由此来提升索引速度,Lucene的API也支持多个索引文件的合并,所以采用这种方式来建索
引,也能够大大的提升索引性能,这种方式尤其适用于对数据库的数据建索引,我们可以采用分页读的方式,由某个固定数目的线程来建索引。
本篇散仙就来介绍下,如何使用LuceneD的API
来对多个索引文件进行合并操作,合并操作大多数时候要求我们的数据结构是要一致的,当然Lucene是一种文档型的松散的存储结构,某个文档里也可以存储
自己特有的字段,而其他的文档里,则没有,不过既然是我们需要合并,那么就要求大多数的结构是要一致的,否则两个完全不同类型的索引,合并到一起也是不符
合逻辑的。
散仙为了演示合并,就建立了2份索引,然后对这两份索引进行合并。截图如下:


合并的核心代码如下:
<pre name="code" class="java">/***
* @author 秦东亮
* lucene 技术交流群:324714439
* 测试多个索引之间
* 进行合并的方法
* **/
public static void combineMoreIndex(){
try{
Directory d1=FSDirectory.open(new File("E:\\1\\a"));//打开存放索引1的路径
Directory d2=FSDirectory.open(new File("E:\\2\\a"));//打开存放索引2的路径
Directory d3=FSDirectory.open(new File("E:\\3\\ab"));//合并到索引3里面
IndexWriter writer=new IndexWriter(d3, new IndexWriterConfig(Version.LUCENE_44, new IKAnalyzer()));
writer.addIndexes(d1,d2);//传入各自的Diretory或者IndexReader进行合并
writer.commit();//提交索引
writer.close();
System.out.println("合并索引完毕.........");
}catch(Exception e){
e.printStackTrace();
}
}</pre>
生成的第三份索引,截图如下:

下面我们来看下,合并前,1,2索引和合并后的3索引的数据变化信息。
<pre name="code" class="java"> System.out.println("==============1a=========================");
showAll("E:\\1\\a");
System.out.println("==============2a=========================");
showAll("E:\\2\\a");
System.out.println("==============合并后=========================");
showAll("E:\\3\\ab");</pre>
输出结果如下,注意里面有日期为null的,代表这个文档没有日期的这个字段。
<pre name="code" class="java">==============1a=========================
a===&gt;中国 日期: ===&gt; null
b===&gt;法国 日期: ===&gt; 1389783935597
c===&gt;中国 日期: ===&gt; null
d===&gt;英国 日期: ===&gt; null
==============2a=========================
q===&gt;中国 日期: ===&gt; null
w===&gt;法国 日期: ===&gt; 1389783980586
r===&gt;中国 日期: ===&gt; null
d===&gt;英国 日期: ===&gt; null
==============合并后=========================
a===&gt;中国 日期: ===&gt; null
b===&gt;法国 日期: ===&gt; 1389783935597
c===&gt;中国 日期: ===&gt; null
d===&gt;英国 日期: ===&gt; null
q===&gt;中国 日期: ===&gt; null
w===&gt;法国 日期: ===&gt; 1389783980586
r===&gt;中国 日期: ===&gt; null
d===&gt;英国 日期: ===&gt; null
</pre>
http://www.iteye.com/job/topic/1133159的更多相关文章
- HBase如何选取split point
hbase region split操作的一些细节,具体split步骤很多文档都有说明,本文主要关注regionserver如何选取split point 首先推荐web ui查看hbase regi ...
- jvm的代码缓存耗尽导致性能下降
在没遇到这个问题之前,我对JVM的解释模式与编译模式的代码性能相差有多大,是没有感觉的,只是觉得编译模式会比解释模式性能好那么一点点吧. 但是经历过这次以后,让我对JVM的即时编译产生了兴趣.先来看看 ...
- kill新号专题
一.在tomcat启动脚本中看到,kill -3
- javascript 解析dom字符串
知识要求:1:熟悉dom结构层次(如childNodes,nodeType,parent,children)等. 2:熟悉jq对象转换js 对象,反之 毕竟不是专业js人.借助第3方框架.其实jq也是 ...
- 关于Thread.getContextClassLoader的使用场景问题
Thread context class loader存在的目的主要是为了解决parent delegation机制下无法干净的解决的问题.假如有下述委派链: ClassLoader A -> ...
- JAVA 汇编语言查看
http://blog.csdn.net/bingduanlbd/article/details/8524300 http://hllvm.group.iteye.com/group/topic/34 ...
- Clr core
http://hllvm.group.iteye.com/group/topic/43559
- DisableExplicitGC和Direct ByteBuffer
直接堆外内存请参见:http://blog.csdn.net/lantian0802/article/details/39257087 JVM调优请参见:http://hllvm.group.itey ...
- 分析java程序中cpu占用过高的线程
http://blog.csdn.net/jgwei/article/details/12079147 http://hllvm.group.iteye.com/group/topic/38893 h ...
随机推荐
- chapter11_1 Lua数组、列表
Lua中的table可以表示其他语言提供的数据结构:数组.记录.线性表.队列.集合等. 在Lua中很少编写搜索算法,因为table本身就提供了直接访问任意类型的功能. 数组 使用整数来索引table即 ...
- Nginx负载均衡反向代理 后端Nginx获取客户端真实IP
Nginx 反向代理后,后端Nginx服务器无法正常获取客户端的真实IP nginx通过http_realip_module模块来实现的这需要重新编译,如果提前编译好了就无需重新编译了1,重新编译ng ...
- Tomcat7调优及JVM性能优化for Linux环境
标签: tomcat7 jvm 性能 分享到: 出处:http://www.iteye.com 该优化针对Linux X86_X64环境 1. Tomcat优化其实就是对server.xml优化(开户 ...
- Raft详解分析
1.投票部分 一个candidate向所有其他的server发送RequesetVote RPC(具体格式见论文),每次从RPC的reply中累加voteCount,如果超过一半,这个candidat ...
- Hbase查看
Client HBase Client使用HBase的RPC机制与HMaster和HRegionServer进行通信,对于管理类操作,Client与HMaster进行RPC:对于数据读写类操作,Cli ...
- 关于PS的一些总结
1.设计给的图,单独用里边的个别图层 打开图 — 新建一个图层(ctrl+n) — (点开上面的窗口排列-垂直排列,左下边下边自动选择改成图层)—选择移动工具,选中要移动的图层,拉到新建文件夹中. ...
- [转载]Linux 环境下编译 0.11版本内核 kernel
最近在看<.如果Clobber/Modify 为空,则其前面的冒号(:)必须省略. 2.如果Output,Input,Clobber/Modify都为空,Output,Input之前的冒号(:) ...
- nmon的安装与使用
nmon的安装与使用 1.下载 nmon:http://nmon.sourceforge.net/pmwiki.php?n=Site.Download nmonanalyser http://www. ...
- Bootstrap 3 与 Foundation 5
开发工程师, 使用 Bootstrap. 前端开发人员, 使用 Foundation. 我们来谈谈为什么. Bootstrap 与 Foundation 有许多关键的区别, 但是, 我想你只需要记住一 ...
- iOS 的 APP 如何适应 iPhone 5s/6/6Plus 三种屏幕的尺寸?
初代iPhone 2007年,初代iPhone发布,屏幕的宽高是 320 x 480 像素.下文也是按照宽度,高度的顺序排列.这个分辨率一直到iPhone 3GS也保持不变. 那时编写iOS的App( ...