zoukankan      html  css  js  c++  java
  • Lucene之IndexWriter的锁机制(备忘)

           在删除某个索引的时候,会在索引文件所在的目录下生成一个xx.lock文件,这个文件的生成是在deleteDocuments方法执行时,如果删除完毕不关闭的情况下如下:    

     IndexWriter writer=new IndexWriter(FSDirectory.open(new File(config.getIndexFilePath())),new StandardAnalyzer(Version.LUCENE_CURRENT),MaxFieldLength.UNLIMITED);
       //writer.deleteAll();
       Term term=new Term("NAME", "杭州");
       writer.deleteDocuments(term);
       System.out.println("删除完成...");
    

          这个lock文件会继续存在。只有执行writer.close(),这个lock文件才会清除。如果你发现你的索引文件下的目录,在没有使用的情况下有这个lock文件,那说明你的writer没有关闭,同时也有可能说明你的索引并发存在问题、索引已经损坏。同时,要注意虽然IndexWriter是线程安全的,但是它必须要是单利。不能让多线程操作多个IndexWriter。

      

  • 相关阅读:
    saltstack
    python一个命令开启http服务器
    常用服务安装部署
    位置1
    linux中python3安装和使用
    Linux基础系统优化
    Shell基本命令
    linux系统目录结构
    远程连接linux服务器
    VMware和Centos安装使用
  • 原文地址:https://www.cnblogs.com/likehua/p/2354490.html
Copyright © 2011-2022 走看看