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 ...
随机推荐
- Java初学几个程序背诵
1.Hello world class first { public static void main(String[] args){ System.out.println("Hello w ...
- bzoj1876 SuperGCD
Description Sheng bill有着惊人的心算能力,甚至能用大脑计算出两个巨大的数的GCD(最大公约 数)!因此他经常和别人比赛计算GCD.有一天Sheng bill很嚣张地找到了你,并要 ...
- 原创)CentOS6.4下安装xampp(一定要在linux上下载)
一.xampp下载地址: http://sourceforge.net/projects/xampp/files/XAMPP%20Linux/1.8.3/ 二.我下载的是xampp-linux-x64 ...
- Redis 密码设置和查看密码
Redis 密码设置和查看密码 redis没有实现访问控制这个功能,但是它提供了一个轻量级的认证方式,可以编辑redis.conf配置来启用认证. 1.初始化Redis密码: 在配置文件中有个参数: ...
- [UE4]Visual Studio的相关插件安装:UE4.natvis和UnrealVS Extension
转自:http://aigo.iteye.com/blog/2281182 UE4.natvis 官方文档: https://docs.unrealengine.com/latest/INT/Prog ...
- golang web框架 beego 学习 (四) 连接mysql
1 DB参数配置在app.conf appname = gowebProject httpport = runmode = dev [db] host= localhost port= databas ...
- RNN总结
RNN既可以表述为循环神 经网络(recurrent neural network),也可以表述为递归神经网络(recursive neural network),前者一般用于处理以时间序列为输入的问 ...
- js 下关于json的销毁和添加
var json={a:1,b:2} 现在给json添加个c,可以这样写 json.c=3或json["c"]=3 我删除一个属性 delete json.a alert(json ...
- 【BZOJ】1101 [POI2007]Zap(莫比乌斯反演)
题目 传送门:QWQ 分析 莫比乌斯反演. 还不是很熟练qwq 代码 //bzoj1101 //给出a,b,d,询问有多少对二元组(x,y)满足gcd(x,y)=d.x<=a,y<=b # ...
- pycharm下getpass.getpass()卡住
pycharm下getpass.getpass()卡住不运行是什么问题 python pycharm 首先声明 下面这几行代码在命令行和eclipse下都能正常运行 import getpass pr ...