您好,登錄后才能下訂單哦!
本篇內容介紹了“Lucene怎樣獲取Reader”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
由于現在網絡搜索都希望達到實時搜索的效果,用戶上傳文章后,希望立即在搜索結果中可見,這就要求我們必須使用Lucene的準實時搜索功能,使我們在不影響性能的情況下達到近實時搜索的效果。然而準實時搜索API在4.x版本中已經與3.x版本完全不同了。
首先來看怎樣獲取準實時搜索的Reader實例,大家都知道,由于性能等方面原因,基于Lucene的應用一般都采用共享Lucene的Writer和Reader及Searcher的方案,我們這里也不例外:
indexPathname = "D:/aproject/xincaigu/work/index"; analyzer = new MMSegAnalyzer(); IndexWriterConfig iwc = new IndexWriterConfig(Version.LUCENE_41, analyzer); iwc.setOpenMode(OpenMode.CREATE_OR_APPEND); try { indexDir = FSDirectory.open(new File(indexPathname)); writer = new IndexWriter(indexDir, iwc); // writer和reader整個程序共用 reader = DirectoryReader.open(writer, true); //reader = writer.getReader(); } catch (CorruptIndexException e) { } catch (LockObtainFailedException e) { } catch (IOException e) { }
熟悉Lucene 3.x的朋友一定注意到了,獲取準實時搜索所用的Reader已經改用DirectoryReader.open方法,而不是3.x當中的writer.getReader()方法了。
同樣,在3.x中,為了可以看到剛剛添加的新文章,Reader需要進行reopen操作,這是一種節省資源的方式,可以獲取新加入索引的文章,而不需要將改動保存到磁盤上,然后重新打開索引的方式來進行了。但是reopne在4.x也被新API所取代,具體的用法如下所示:
try { IndexReader newReader = DirectoryReader.openIfChanged((DirectoryReader)reader, writer, false);//reader.reopen(); // 讀入新增加的增量索引內容,滿足實時索引需求 if (newReader != null) { reader.close(); reader = newReader; } searcher = new IndexSearcher(reader); } catch (CorruptIndexException e) { } catch (IOException e) {
這里首先利用新APIDirctoryReader.openIfChanged來獲取Reader,如果有新內容,則返回新的Reader,這時我們需要關閉老的Reader。
“Lucene怎樣獲取Reader”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。