操作系统都会限制一个进程同时打开文件的最大数量,通常linux默认的是1024.lucene有可能会导致“Too many open files”的异常,这取决于你是否正确使用lucene。
1.总是要确保打开的文件句柄关闭掉,特别是出现错误的情况,捕获该异常,并在finally块释放持有的文件句柄。请记住,java没有拆构器,不要在finalize方法里处理文件句柄,该方法不会确保都被执行的。
2.打开IndexWriter的复合模式---IndexWriter's setUseCompoundFile(true),它会减少lucene在写时的索引文件数量。
3. 不要设置一个过大的IndexWriter's mergeFactor,虽然mergeFactor越大索引数据越快,但同时也会增加打开的索引文件数。
4.如果在检索时遇到异常,调用IndexWriter's optimize()来优化索引,在优化时不能写索引。
5.确保你只实例化一个IndexSearcher,它是线程安全的,可以被多个线程同时使用。
6.调大允许一个进程同时打开的文件数,linux下设置文件数:ulimit -n <number>.
1.总是要确保打开的文件句柄关闭掉,特别是出现错误的情况,捕获该异常,并在finally块释放持有的文件句柄。请记住,java没有拆构器,不要在finalize方法里处理文件句柄,该方法不会确保都被执行的。
2.打开IndexWriter的复合模式---IndexWriter's setUseCompoundFile(true),它会减少lucene在写时的索引文件数量。
3. 不要设置一个过大的IndexWriter's mergeFactor,虽然mergeFactor越大索引数据越快,但同时也会增加打开的索引文件数。
4.如果在检索时遇到异常,调用IndexWriter's optimize()来优化索引,在优化时不能写索引。
5.确保你只实例化一个IndexSearcher,它是线程安全的,可以被多个线程同时使用。
6.调大允许一个进程同时打开的文件数,linux下设置文件数:ulimit -n <number>.