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 ...
随机推荐
- Angular 4 表单校验2
1. 将表单的方法移动到单独的ts文件夹中 2. code export function mobileValidator(control: FormControl): any { const myr ...
- golang fmt用法举例
下标与参数的对应 例子如下: package main import ( "fmt" ) func main() { num := 10 fmt.Printf("num: ...
- Excel数组排序+图片统一大小
Sub 图片调整合适大小() ' Debug.Print ActiveWorkbook.Name 图片显示比例 = 0.9 '1为顶满单元格 Dim wb As Workbook, sh As Wor ...
- maven学习(4)-Maven 构建Web 项目
紧接着上一节(3),现在maven新建web项目,user-web.模拟一个用户登录的需求: 工程结构: pom.xml: <project xmlns="http://maven.a ...
- springMVC参数绑定JSON类型的数据
需求就是: 现在保存一个Student,并且保存Student的friend,一个student会有多个朋友,这里要传递到后台的参数是: var friends = new Array(); var ...
- Python- 解决PIP下载安装速度慢 让PIP源使用国内镜像,提升下载速度和安装成功率。
原文: https://www.cnblogs.com/microman/p/6107879.html 对于Python开发用户来讲,PIP安装软件包是家常便饭.但国外的源下载速度实在太慢,浪费时间. ...
- [UE4]动画序列面板
- VS Code 基本介绍 和 快捷键
简介 VSCode是微软推出的一款轻量编辑器,采取了和VS相同的UI界面,搭配合适的插件可以大幅提升前端开发的效率. 布局:左侧是用于展示所要编辑的所有文件和文件夹的文件管理器,依次是:资源管理器,搜 ...
- FDD vs TDD
双工方式 FDD vs TDD 频分双工(FDD) 收发信各占用一个频率. 优点是收.发信号同时进行,时延小,技术成熟,缺点是设备成本高. 时分双工(TDD) 收发信使用同一个频率,但使用不同 ...
- 一,Android Studio笔记
转自:https://developer.android.com/studio/intro/index.html 一.界面 Android Studio 主窗口由图 3 标注的几个逻辑区域组成. 工具 ...