LockObtainFailedException: Lock obtain timed out:

本文探讨了在使用Lucene进行全索引删除时遇到的LockObtainFailedException异常,通过代码调整解决了因同时创建多个写入流导致的问题。

学习lucene测试索引全删除时报异常

org.apache.lucene.store.LockObtainFailedException: Lock obtain timed out: NativeFSLock@F:\Lucene&solr\index\write.lock
	at org.apache.lucene.store.Lock.obtain(Lock.java:89)
	at org.apache.lucene.index.IndexWriter.<init>(IndexWriter.java:753)
	at com.itheima.lucene.luceneManager.getIndexWriter(luceneManager.java:22)
	at com.itheima.lucene.luceneManager.testAllDelete(luceneManager.java:27)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
	at 。。。。

代码为:

public IndexWriter getIndexWriter() throws IOException{
		Analyzer analyzer = new StandardAnalyzer();
		IndexWriterConfig config = new IndexWriterConfig(Version.LUCENE_4_10_3, analyzer);
		Directory directory = FSDirectory.open(new File("F:\\Lucene&solr\\index"));
		return new IndexWriter(directory, config);
	}
	@Test
	public void testAllDelete() throws Exception {
		getIndexWriter().deleteAll();
		getIndexWriter().close();
		
	}

修改后正常

public IndexWriter getIndexWriter() throws IOException{
		Analyzer analyzer = new StandardAnalyzer();
		IndexWriterConfig config = new IndexWriterConfig(Version.LUCENE_4_10_3, analyzer);
		Directory directory = FSDirectory.open(new File("F:\\Lucene&solr\\index"));
		return new IndexWriter(directory, config);
	}
	@Test
	public void testAllDelete() throws Exception {
		IndexWriter indexWriter = getIndexWriter();
		indexWriter.deleteAll();
		indexWriter.close();
		
	}

应该是前者创建了两个写入流的原因

[2025-08-27T04:10:31,691][INFO ][o.e.p.PluginsService ] [node-1] no plugins loaded [2025-08-27T04:10:37,953][ERROR][o.e.b.Elasticsearch ] [node-1] fatal exception while booting Elasticsearch java.lang.IllegalStateException: failed to obtain node locks, tried [/usr/local/elasticsearch-8.4.0/data]; maybe these locations are not writable or multiple nodes were started on the same data path? at org.elasticsearch.env.NodeEnvironment.<init>(NodeEnvironment.java:285) ~[elasticsearch-8.4.0.jar:?] at org.elasticsearch.node.Node.<init>(Node.java:456) ~[elasticsearch-8.4.0.jar:?] at org.elasticsearch.node.Node.<init>(Node.java:311) ~[elasticsearch-8.4.0.jar:?] at org.elasticsearch.bootstrap.Elasticsearch$2.<init>(Elasticsearch.java:214) ~[elasticsearch-8.4.0.jar:?] at org.elasticsearch.bootstrap.Elasticsearch.initPhase3(Elasticsearch.java:214) ~[elasticsearch-8.4.0.jar:?] at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:67) ~[elasticsearch-8.4.0.jar:?] Caused by: org.apache.lucene.store.LockObtainFailedException: Lock held by another program: /usr/local/elasticsearch-8.4.0/data/node.lock at org.apache.lucene.store.NativeFSLockFactory.obtainFSLock(NativeFSLockFactory.java:117) ~[lucene-core-9.3.0.jar:?] at org.apache.lucene.store.FSLockFactory.obtainLock(FSLockFactory.java:43) ~[lucene-core-9.3.0.jar:?] at org.apache.lucene.store.BaseDirectory.obtainLock(BaseDirectory.java:44) ~[lucene-core-9.3.0.jar:?] at org.elasticsearch.env.NodeEnvironment$NodeLock.<init>(NodeEnvironment.java:223) ~[elasticsearch-8.4.0.jar:?] at org.elasticsearch.env.NodeEnvironment$NodeLock.<init>(NodeEnvironment.java:198) ~[elasticsearch-8.4.0.jar:?] at org.elasticsearch.env.NodeEnvironment.<init>(NodeEnvironment.java:277) ~[elasticsearch-8.4.0.jar:?] ... 5 more
最新发布
08-27
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值