Lucene的IndexWriter初始化时的LockObtainFailedException

简介:       系统中刚集成了一段Lucene的代码,用来实现简单的建立索引和搜索的功能。可是重新部署程序时,都会出现下面的异常:   Invocation of init method failed; nested exception is org.

      系统中刚集成了一段Lucene的代码,用来实现简单的建立索引和搜索的功能。可是重新部署程序时,都会出现下面的异常:

 

Invocation of init method failed; nested exception is org.apache.lucene.store.LockObtainFailedException: Lock obtain timed out: NativeFSLock@/home/developer1/tomcat7/bin/index/write.lock

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:527) ~[spring-beans-3.0.5.RELEASE.jar:3.0.5.RELEASE]

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456) ~[spring-beans-3.0.5.RELEASE.jar:3.0.5.RELEASE]

at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:291) ~[spring-beans-3.0.5.RELEASE.jar:3.0.5.RELEASE]

导致整个程序中的Spring Bean初始化都失败了。

      进到索引目录中,发现里面就是一个write.lock。而IndexWriter的构造函数在试图获取另外一个IndexWriter已经加锁的索引目录时就会抛出一个LockObtainFailedException。

      最直接的想法就是在程序undeploy时释放锁。好在Spring提供了非常方便的方式来实现这个功能。bean需要实现DisposableBean的借口,并且实现其destroy方法:      

 


public void destroy() throws Exception { if(IndexWriter.isLocked(indexDirectory)){ writer.close(); IndexWriter.unlock(indexDirectory); } } 

程序undeploy以后,再去索引目录下write.lock已经不见了。程序也可以顺利重新发布了。

 

目录
相关文章
|
6月前
|
算法 索引
一篇文章讲明白Lucene学习总结之九:Lucene的查询对象(2)
一篇文章讲明白Lucene学习总结之九:Lucene的查询对象(2)
25 0
|
索引
07Lucene索引库的修改
07Lucene索引库的修改
37 0
|
索引
06Lucene索引库的删除
06Lucene索引库的删除
47 0
|
存储 自然语言处理 索引
05Lucene索引库的添加
05Lucene索引库的添加
42 0
|
自然语言处理 搜索推荐 Java
Lucene简单使用
Lucene简单使用
92 0
|
自然语言处理 算法 数据库
lucene使用的一些注意事项 | 学习笔记
快速学习lucene使用的一些注意事项。
|
缓存 Java 索引
Solr&Lucene cache简要汇总
假期重新把之前在新浪博客里面的文字梳理了下,搬到这里。本文汇总Solr Lucene cache相关内容。撇开系统结构、架构这些整体性的分析,纯粹从使用方面做梳理。
229 0
Solr&Lucene cache简要汇总
|
缓存 自然语言处理 安全
lucene原理及源码解析--核心类(下)
访问者模式把数据结构和作用于结构上的操作解耦合,使得操作集合可相对自由地演化。具体到这个类就是不管是什么类型的数据,我都把它添加到Document对象里。
lucene原理及源码解析--核心类(下)
|
存储 设计模式 大数据
lucene原理及源码解析--核心类(上)
马云说:大家还没搞清PC时代的时候,移动互联网来了,还没搞清移动互联网的时候,大数据时代来了。 然而,我看到的是:在PC时代搞PC的,移动互联网时代搞移动互联网的,大数据时代搞大数据的,都是同一伙儿人。 我就是一个做业务方向的,而回忆起真正做技术的时光,也就是大数据时代刚来临的时候做搜索了。 搜索用的是solr框架,solr就是包装了lucene实现了近实时索引。所以源头还是lucene。而且lucene是java写的全文检索库,源码是一定要研究一下的。
lucene原理及源码解析--核心类(上)