Lucene IndexReader,IndexWriter,IndexSearcher 缓存应用
1.IndexManager类,用于提供IndexReader,IndexWriter,IndexSearcher获取接口
import java.io.File;
import java.io.IOException;
import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.index.IndexReader;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.index.IndexWriterConfig;
import org.apache.lucene.index.IndexWriterConfig.OpenMode;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.store.Directory;
import org.apache.lucene.store.FSDirectory;
import org.apache.lucene.util.Version;
publicclass IndexManager{
/**
*所有writer公共配置
*/
privatestaticfinal IndexWriterConfig iwc = new IndexWriterConfig(Version.LUCENE_44, newStandardAnalyzer(Version.LUCENE_44));
static {
iwc.setOpenMode(OpenMode.CREATE_OR_APPEND);
iwc.setRAMBufferSizeMB(20.0);
iwc.setMaxBufferedDocs(10000);
}
private Directory dir;
private IndexReader reader;
private IndexSearcher searcher;
private IndexWriter writer;
/**
*构造函数
*@paramindexPath
*/
public IndexManager(String indexPath) {
init(new File(indexPath));
}
/**
*构造函数
*@paramindexPath
*/
public IndexManager(File dirFile) {
init(dirFile);
}
privatevoid init(File dirFile) {
try {
dir = FSDirectory.open(dirFile);
//根据Directory对象,初始化indexReader对象
ReaderManager.getInstance().createIndexReader(dir);
//初始化writer对象
writer = new IndexWriter(dir, iwc);
} catch (IOException e) {
e.printStackTrace();
}
}
public IndexSearcher getSearcher() {
IndexReader ir = ReaderManager.getInstance().getIndexReader(dir);
if(reader == null || reader != ir)
{
reader = ir;
searcher = new IndexSearcher(reader);
}
returnsearcher;
}
public IndexWriter getWriter() {
returnwriter;
}
publicvoid commitWriter()
{
try {
writer.commit();
} catch (IOException e) {
rollback();
}
}
privatevoid rollback() {
try {
writer.rollback();
} catch (IOException e1) {
e1.printStackTrace();
}
}
}
2.ReaderManager类,用于提供IndexReader生命周期管理
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
import java.util.Timer;
import java.util.TimerTask;
import java.util.Map.Entry;
import org.apache.lucene.index.DirectoryReader;
import org.apache.lucene.index.IndexReader;
import org.apache.lucene.store.Directory;
/**
*IndexReader生命周期,以及改变后reopen管理类
*@authoradmin
*
*/
publicclass ReaderManager {
/**
*reader回收Map
*/
privatestaticfinal Map<DirectoryReader, Long> recyleReaderMap = new HashMap<DirectoryReader, Long>();
/**
*oldreader回收最大生命周期
*/
privatestaticfinalintoldReaderMaxLifeTime = 60 * 1000;
privatestaticfinal Timer readerRefereshTimer = new Timer();
privatestaticfinal Map<Directory, DirectoryReader> readerMap = newHashMap<Directory, DirectoryReader>();
privatestaticfinal ReaderManager manager = new ReaderManager();
publicstaticfinalsynchronized ReaderManager getInstance()
{
returnmanager;
}
/**
*创建indexReader并放缓存
*@paramreader
*/
publicsynchronizedvoid createIndexReader(Directory dir)
{
try {
readerMap.put(dir, DirectoryReader.open(dir));
} catch (IOException e) {
e.printStackTrace();
}
}
/**
*获取IndexReader
*@paramdir
*@return
*/
public IndexReader getIndexReader(Directory dir)
{
returnreaderMap.get(dir);
}
static
{
readerRefereshTimer.schedule(new TimerTask(){
publicvoid run() {
//判断处理reader是否改变
for (Entry<Directory, DirectoryReader> entry : newHashMap<Directory, DirectoryReader>(readerMap).entrySet()) {
try {
DirectoryReader oldReader = entry.getValue();
DirectoryReader newReader = DirectoryReader.openIfChanged(oldReader);
if(newReader != null)
{
//替换旧reader对象
readerMap.put(entry.getKey(), newReader);
//放入回收MAP中
recyleReaderMap.put(oldReader, System.currentTimeMillis());
}
} catch (IOException e) {
e.printStackTrace();
}
}
//处理old reader回收
for (Entry<DirectoryReader, Long> entry : newHashMap<DirectoryReader, Long>(recyleReaderMap).entrySet()) {
if(System.currentTimeMillis() - entry.getValue()> oldReaderMaxLifeTime)
{
try {
entry.getKey().close();
} catch (IOException e) {
e.printStackTrace();
} finally {
recyleReaderMap.remove(entry.getKey());
}
}
}
}
}, 5 * 1000, 5 * 1000);
}
}
Lucene IndexReader,IndexWriter,IndexSearcher 缓存应用的更多相关文章
- Cache Lucene IndexReader with Apache Commons Pool
IndexReaderFactory.java 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 2 ...
- 关于lucene的IndexSearcher单实例,对于索引的实时搜索
Lucene版本:3.0 一般情况下,lucene的IndexSearcher都要写成单实例,因为每次创建IndexSearcher对象的时候,它都需要把索引文件加载进来,如果访问量比较大,而索引也比 ...
- Lucene.net(4.8.0) 学习问题记录三: 索引的创建 IndexWriter 和索引速度的优化
前言:目前自己在做使用Lucene.net和PanGu分词实现全文检索的工作,不过自己是把别人做好的项目进行迁移.因为项目整体要迁移到ASP.NET Core 2.0版本,而Lucene使用的版本是3 ...
- Lucene系列五:Lucene索引详解(IndexWriter详解、Document详解、索引更新)
一.IndexWriter详解 问题1:索引创建过程完成什么事? 分词.存储到反向索引中 1. 回顾Lucene架构图: 介绍我们编写的应用程序要完成数据的收集,再将数据以document的形式用lu ...
- Lucene 更新、删除、分页操作以及IndexWriter优化
更新操作如下: 注意:通过lukeall-1.0.0.jar 查看软件,我们可以看到,更新其实是先删除在插入, 前面我们知道索引库中有两部分的内容组成,一个是索引文件,另一个是目录文件, 目前我们更新 ...
- lucene中的IndexWriter.setMaxFieldLength()
lucene中的IndexWriter.setMaxFieldLength() 老版本的Lucene中,IndexWriter的maxFieldLength是指一个索引中的最大的Field个数. 这个 ...
- Lucene的分析资料【转】
Lucene 源码剖析 1 目录 2 Lucene是什么 2.1.1 强大特性 2.1.2 API组成- 2.1.3 Hello World! 2.1.4 Lucene roadmap 3 索引文件结 ...
- 【Java】Lucene检索引擎详解
基于Java的全文索引/检索引擎——Lucene Lucene不是一个完整的全文索引应用,而是是一个用Java写的全文索引引擎工具包,它可以方便的嵌入到各种应用中实现针对应用的全文索引/检索功能. L ...
- lucene 搜索引擎使用案例
1.使用定时框架Quartz.Net创建索引库,引用类库文件有Common.Logging.dll.Lucene.Net.dll,PanGu.dll,PanGu.HighLight.dll,PanGu ...
随机推荐
- ext 扩展控件—moneyField
/** *数字控件 *带大写提示,和千分位 **/ Ext.define(appNameSpace+'.utils.MoneyField', { extend : 'Ext.form.field.Te ...
- 利用def生成dll文件
DLL中导出函数的声明有两种方式:一种为在函数声明中加上__declspec(dllexport),这里不再举例说明:另外一种方式是采用模块定义(.def) 文件声明,.def文件为链接器提供了有关被 ...
- C# Json反序列化处理
最近换工作了 从客户端转到Web端 第一个任务就是去别人的页面上抓取数据 用到的是JSON 因为他们网站json的格式有点怪 所以 就在JSON反序列化上面 花了一点时间 首先用到的工具是http:/ ...
- ARCI--做事情的重要方法论
很多朋友都可能碰到这样的情况,有一个任务曾经开会讨论过,目标,时间,参与人都有提到,但是最终就是不了了之,没有下文了,而且后面想起来,要追究责任的时候,发现似乎都没有责任,无从追究.如果这种情况出现, ...
- [BZOJ 3129] [Sdoi2013] 方程 【容斥+组合数取模+中国剩余定理】
题目链接:BZOJ - 3129 题目分析 使用隔板法的思想,如果没有任何限制条件,那么方案数就是 C(m - 1, n - 1). 如果有一个限制条件是 xi >= Ai ,那么我们就可以将 ...
- LA 4975
回文串的题,求最大的双重回文串: 重新复习了一下manacher算法: 代码: #include<cstdio> #include<cstring> #include<a ...
- Hibernate 注解多对一 要求在多那边产生一个外键而不会另外产生一个表
在使用hibernate注解的时候,我们映射一对多时,有时候莫名其妙的产生了两张表,其中一张表是A_B,这并不符合数据库中多的一方放置一个外键的原则,那么如何控制只产生一个表呢,请看下面的例子: 多的 ...
- Android 设置隐式意图
AndroidManifest.xml对于被调用的activity: <activity android:name="com.wuyou.twoactivity.OtherActivi ...
- mysql左联右联内联
在MySQL中由于性能的关系,常常要将子查询(Sub-Queries)用连接(join)来却而代之,能够更好地使用表中索引提高查询效率. 下面介绍各种join的使用,先上图: 我们MySQL常用的为左 ...
- I2C读写时序
1. I2C写时序图: 注意:最后一个byte后,结束标志在第十个CLK上升沿之后: 2. I2C读时序图: 注意:restart信号格式:读操作结束前最后一组clk的最后一个上升沿,主机应发送NAC ...