为什么产生“Too many open files”

操作系统都会限制一个进程同时打开文件的最大数量,通常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>.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值