Cache Lucene IndexReader with Apache Commons Pool
IndexReaderFactory.java
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556packageorg.ostree.module.lucene;importorg.apache.commons.pool.KeyedPoolableObjectFactory;importorg.apache.lucene.index.IndexReader;importorg.apache.lucene.store.FSDirectory;importorg.slf4j.Logger;importorg.slf4j.LoggerFactory;importjava.io.File;importjava.util.NoSuchElementException;publicclassIndexReaderFactoryimplementsKeyedPoolableObjectFactory<String, IndexReader> {privateString baseIndexDir="/var/data/ostree/index";privatestaticfinalLogger logger = LoggerFactory.getLogger(IndexReaderFactory.class);publicIndexReaderFactory(String baseIndexDir) {this.baseIndexDir = baseIndexDir;}@OverridepublicIndexReader makeObject(String key)throwsException {logger.info("open index: "+ key);File file=newFile(baseIndexDir,key);if(!file.exists()){thrownewNoSuchElementException(key +" index doesn't exist!");}FSDirectory dir =FSDirectory.open(file);returnIndexReader.open(dir,true);}@OverridepublicvoiddestroyObject(String key, IndexReader reader)throwsException {logger.info("destroy index: "+ key);reader.close();}@OverridepublicbooleanvalidateObject(String key, IndexReader reader) {logger.info("validate index: "+ key);if(reader!=null){returntrue;}returnfalse;}@OverridepublicvoidactivateObject(String key, IndexReader reader)throwsException {logger.debug("activate index: "+ key);}@OverridepublicvoidpassivateObject(String key, IndexReader reader)throwsException {logger.debug("passivate index: "+ key);}}Usage
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152importorg.apache.commons.pool.KeyedObjectPool;importorg.apache.commons.pool.impl.GenericKeyedObjectPool;importorg.apache.commons.pool.impl.GenericKeyedObjectPoolFactory;importorg.apache.lucene.document.Document;importorg.apache.lucene.index.IndexReader;importorg.apache.lucene.index.Term;importorg.apache.lucene.search.IndexSearcher;importorg.apache.lucene.search.NGramPhraseQuery;importorg.apache.lucene.search.ScoreDoc;importorg.apache.lucene.search.TopDocs;publicclassLuceneSearcherPool {publicstaticvoidmain(String[] args) {GenericKeyedObjectPool.Config config =newGenericKeyedObjectPool.Config();GenericKeyedObjectPoolFactory<String, IndexReader> poolFactory =newGenericKeyedObjectPoolFactory<String, IndexReader>(newIndexReaderFactory("/var/data/ostree/index"), config);KeyedObjectPool<String, IndexReader> pool = poolFactory.createPool();try{String[] dates = {"2012-01-01","2011-01-04","2012-01-05"};for(String date : dates) {for(inti =0; i <10; i++) {longstart = System.currentTimeMillis();IndexReader reader = pool.borrowObject(date);test(reader);pool.returnObject(date, reader);System.out.println(date +":"+ i +";"+ (System.currentTimeMillis() - start));}}pool.close();}catch(Exception ex) {}}publicstaticvoidtest(IndexReader reader)throwsException {String input ="java";intnum =5;IndexSearcher searcher =newIndexSearcher(reader);//build your query here//Query query =TopDocs hits = searcher.search(query, num);for(ScoreDoc scoreDoc : hits.scoreDocs) {Document doc = searcher.doc(scoreDoc.doc);// handle the Document}searcher.close();}}
Cache Lucene IndexReader with Apache Commons Pool的更多相关文章
- JedisCluster中应用的Apache Commons Pool对象池技术
对象池技术在服务器开发上应用广泛.在各种对象池的实现中,尤其以数据库的连接池最为明显,可以说是每个服务器必须实现的部分. apache common pool 官方文档可以参考:https://c ...
- Tomcat 开发web项目报Illegal access: this web application instance has been stopped already. Could not load [org.apache.commons.pool.impl.CursorableLinkedList$Cursor]. 错误
开发Java web项目,在tomcat运行后报如下错误: Illegal access: this web application instance has been stopped already ...
- NoClassDefFoundError: org/apache/commons/pool/impl/GenericObjectPool
错误:Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/pool/impl ...
- Spring + Tomcat 启动报错java.lang.ClassNotFoundException: org.apache.commons.pool.impl.GenericObjectPool
错误如下: -- ::,-[TS] INFO http-- org.springframework.beans.factory.support.DefaultListableBeanFactory - ...
- Apache Commons Pool 故事一则
Apache Commons Pool 故事一则 最近工作中遇到一个由于对commons-pool的使用不当而引发的问题,习得正确的使用姿势后,写下这个简单的故事,帮助理解Apache Commons ...
- 池化 - Apache Commons Pool
对于那些创建耗时较长,或者资源占用较多的对象,比如网络连接,线程之类的资源,通常使用池化来管理这些对象,从而达到提高性能的目的.比如数据库连接池(c3p0, dbcp), java的线程池 Execu ...
- org/apache/commons/pool/impl/GenericObjectPool异常的解决办法
org/apache/commons/pool/impl/GenericObjectPool异常的解决办法 webwork+spring+hibernate框架的集成, 一启动Tomcat服务器就出了 ...
- 对象池化技术 org.apache.commons.pool
恰当地使用对象池化技术,可以有效地减少对象生成和初始化时的消耗,提高系统的运行效率.Jakarta Commons Pool组件提供了一整套用于实现对象池化的框架,以及若干种各具特色的对象池实现,可以 ...
- Java_异常_03_ java.lang.NoClassDefFoundError: org/apache/commons/pool/KeyedObjectPoolFactory
异常信息: java.lang.NoClassDefFoundError: org/apache/commons/pool/KeyedObjectPoolFactory 原因: 我用的是commons ...
随机推荐
- php preg_replace空格无法替换问题
一次坑爹的小bug.读取一段文字(编码utf-8),想替换掉空格,str_replace(" "..).preg_replace("/\s/"..)都不起作用. ...
- yum运行时提示被锁住了解决办法
1.当大家用linux的yum时,是不是经常会遇到下面的情况Loaded plugins: fastestmirrorExisting lock /var/run/yum.pid: another c ...
- ORACLE基本操作备忘
通过CMD登录SQLPLUS 的语句 C:\Users\Administrator>sqlplus /nolog SQL> conn sys/pwd as sysdba; 导入导出数据库( ...
- SQL SERVER 2008 彻底卸载干净方法 (转)
最近安装SQL SERVER 2008失败后,再重新安装时老是报错,东搞西搞的很难卸干净.但又不方便重装系统,经按下面方法终于搞定并成功安装上2008 1.停掉SQL SERVER 2008所有相关服 ...
- JZ2440 裸机驱动 第11章 通用异步收发器UART
本章目标: 了解UART原理: 掌握S3C2410/S3C2440中UART的使用 11.1 UART原理及UART内部使用方法 11.1.1 UART原理说明 UART用于传输串行数据: ...
- Android Studio 默认keystore 以及自定义keystore
我们使用Android Studio 运行或测试我们的app 它使用一个默认的debug.keystore进行签名. 这个默认签名(keystore)是不需要密码的,它的默认位置在 $HOME/.a ...
- 分布式一致性协议之:Gossip(八卦)算法
Gossip算法因为Cassandra而名声大噪,Gossip看似简单,但要真正弄清楚其本质远没看起来那么容易.为了寻求Gossip的本质,下面的内容主要参考Gossip的原始论文:<<E ...
- [转]预编译 ASP.NET 网站
转自:如何:预编译 ASP.NET 网站 Visual Studio 2005 预编译 ASP.NET 网站可缩短用户的初始响应时间,因为页在第一次被请求时无需编译.这对于经常更新的大型网站尤其有 ...
- 【转载】如何在 Github 上发现优秀的开源项目?
之前发过一系列有关 GitHub 的文章,有同学问了,GitHub 我大概了解了,Git 也差不多会使用了,但是还是搞不清 GitHub 如何帮助我的工作,怎么提升我的工作效率? 问到点子上了,Git ...
- Hadoop恢复namenode数据
情景再现: 在修复hadoop集群某一个datanode无法启动的问题时,搜到有一个答案说要删除hdfs-site.xml中dfs.data.dir属性所配置的目录,再重新单独启动该datanode即 ...