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();}}

浙公网安备 33010602011771号