當前位置: 首頁>>代碼示例>>Java>>正文


Java AlreadyClosedException類代碼示例

本文整理匯總了Java中org.apache.lucene.store.AlreadyClosedException的典型用法代碼示例。如果您正苦於以下問題:Java AlreadyClosedException類的具體用法?Java AlreadyClosedException怎麽用?Java AlreadyClosedException使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


AlreadyClosedException類屬於org.apache.lucene.store包,在下文中一共展示了AlreadyClosedException類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: commit

import org.apache.lucene.store.AlreadyClosedException; //導入依賴的package包/類
/**
 * Commits any changes since the last commit or rollback.
 * Afterwards a new {@link IndexReader} will be created.
 * @throws IOException if there is a low-level IO error
 */
void commit() throws IOException {
	try {
		writer.commit();

		if(writer.hasDeletions()) {
			writer.forceMergeDeletes(); // delete now the documents which are marked to delete.
		}
	}
	catch(final AlreadyClosedException e) {
		reopenIndex();
	}
	finally {
		unlock();

		// new reader because new data is available.
		createReader();
	}
}
 
開發者ID:XMBomb,項目名稱:InComb,代碼行數:24,代碼來源:Index.java

示例2: flushAndClose

import org.apache.lucene.store.AlreadyClosedException; //導入依賴的package包/類
/**
 * Flush the engine (committing segments to disk and truncating the
 * translog) and close it.
 */
public void flushAndClose() throws IOException {
    if (isClosed.get() == false) {
        logger.trace("flushAndClose now acquire writeLock");
        try (ReleasableLock lock = writeLock.acquire()) {
            logger.trace("flushAndClose now acquired writeLock");
            try {
                logger.debug("flushing shard on close - this might take some time to sync files to disk");
                try {
                    flush(); // TODO we might force a flush in the future since we have the write lock already even though recoveries are running.
                } catch (AlreadyClosedException ex) {
                    logger.debug("engine already closed - skipping flushAndClose");
                }
            } finally {
                close(); // double close is not a problem
            }
        }
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:23,代碼來源:Engine.java

示例3: maybeFailEngine

import org.apache.lucene.store.AlreadyClosedException; //導入依賴的package包/類
@Override
protected boolean maybeFailEngine(String source, Exception e) {
    boolean shouldFail = super.maybeFailEngine(source, e);
    if (shouldFail) {
        return true;
    }
    // Check for AlreadyClosedException -- ACE is a very special
    // exception that should only be thrown in a tragic event. we pass on the checks to failOnTragicEvent which will
    // throw and AssertionError if the tragic event condition is not met.
    if (e instanceof AlreadyClosedException) {
        return failOnTragicEvent((AlreadyClosedException)e);
    } else if (e != null &&
            ((indexWriter.isOpen() == false && indexWriter.getTragicException() == e)
                    || (translog.isOpen() == false && translog.getTragicException() == e))) {
        // this spot on - we are handling the tragic event exception here so we have to fail the engine
        // right away
        failEngine(source, e);
        return true;
    }
    return false;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:22,代碼來源:InternalEngine.java

示例4: maybeFSyncTranslogs

import org.apache.lucene.store.AlreadyClosedException; //導入依賴的package包/類
private void maybeFSyncTranslogs() {
    if (indexSettings.getTranslogDurability() == Translog.Durability.ASYNC) {
        for (IndexShard shard : this.shards.values()) {
            try {
                Translog translog = shard.getTranslog();
                if (translog.syncNeeded()) {
                    translog.sync();
                }
            } catch (AlreadyClosedException ex) {
                // fine - continue;
            } catch (IOException e) {
                logger.warn("failed to sync translog", e);
            }
        }
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:17,代碼來源:IndexService.java

示例5: maybeRefreshEngine

import org.apache.lucene.store.AlreadyClosedException; //導入依賴的package包/類
private void maybeRefreshEngine() {
    if (indexSettings.getRefreshInterval().millis() > 0) {
        for (IndexShard shard : this.shards.values()) {
            switch (shard.state()) {
                case CREATED:
                case RECOVERING:
                case CLOSED:
                    continue;
                case POST_RECOVERY:
                case STARTED:
                case RELOCATED:
                    try {
                        if (shard.isRefreshNeeded()) {
                            shard.refresh("schedule");
                        }
                    } catch (IndexShardClosedException | AlreadyClosedException ex) {
                        // fine - continue;
                    }
                    continue;
                default:
                    throw new IllegalStateException("unknown state: " + shard.state());
            }
        }
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:26,代碼來源:IndexService.java

示例6: maybeUpdateGlobalCheckpoints

import org.apache.lucene.store.AlreadyClosedException; //導入依賴的package包/類
private void maybeUpdateGlobalCheckpoints() {
    for (IndexShard shard : this.shards.values()) {
        if (shard.routingEntry().primary()) {
            switch (shard.state()) {
                case CREATED:
                case RECOVERING:
                case CLOSED:
                case RELOCATED:
                    continue;
                case POST_RECOVERY:
                case STARTED:
                    try {
                        shard.updateGlobalCheckpointOnPrimary();
                    } catch (AlreadyClosedException ex) {
                        // fine - continue, the shard was concurrently closed on us.
                    }
                    continue;
                default:
                    throw new IllegalStateException("unknown state: " + shard.state());
            }
        }
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:24,代碼來源:IndexService.java

示例7: handleRefreshException

import org.apache.lucene.store.AlreadyClosedException; //導入依賴的package包/類
private void handleRefreshException(Exception e) {
    if (e instanceof AlreadyClosedException) {
        // ignore
    } else if (e instanceof RefreshFailedEngineException) {
        RefreshFailedEngineException rfee = (RefreshFailedEngineException) e;
        if (rfee.getCause() instanceof InterruptedException) {
            // ignore, we are being shutdown
        } else if (rfee.getCause() instanceof ClosedByInterruptException) {
            // ignore, we are being shutdown
        } else if (rfee.getCause() instanceof ThreadInterruptedException) {
            // ignore, we are being shutdown
        } else {
            if (state != IndexShardState.CLOSED) {
                logger.warn("Failed to perform engine refresh", e);
            }
        }
    } else {
        if (state != IndexShardState.CLOSED) {
            logger.warn("Failed to perform engine refresh", e);
        }
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:23,代碼來源:IndexShard.java

示例8: testAddingAClosedReader

import org.apache.lucene.store.AlreadyClosedException; //導入依賴的package包/類
public void testAddingAClosedReader() throws Exception {
    LeafReader reader;
    try (Directory dir = newDirectory();
            RandomIndexWriter writer = new RandomIndexWriter(random(), dir)) {
        writer.addDocument(new Document());
        try (DirectoryReader dirReader = ElasticsearchDirectoryReader.wrap(writer.getReader(), new ShardId("index1", "_na_", 1))) {
            reader = dirReader.leaves().get(0).reader();
        }
    }
    ShardCoreKeyMap map = new ShardCoreKeyMap();
    try {
        map.add(reader);
        fail("Expected AlreadyClosedException");
    } catch (AlreadyClosedException e) {
        // What we wanted
    }
    assertEquals(0, map.size());
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:19,代碼來源:ShardCoreKeyMapTests.java

示例9: execute

import org.apache.lucene.store.AlreadyClosedException; //導入依賴的package包/類
/**
 * Executes the provided operation against this store
 */
// we can do FS ops with only two elevated permissions:
// 1) hadoop dynamic proxy is messy with access rules
// 2) allow hadoop to add credentials to our Subject
<V> V execute(Operation<V> operation) throws IOException {
    SpecialPermission.check();
    if (closed) {
        throw new AlreadyClosedException("HdfsBlobStore is closed: " + this);
    }
    try {
        return AccessController.doPrivileged((PrivilegedExceptionAction<V>)
                () -> operation.run(fileContext), null, new ReflectPermission("suppressAccessChecks"),
                 new AuthPermission("modifyPrivateCredentials"), new SocketPermission("*", "connect"));
    } catch (PrivilegedActionException pae) {
        throw (IOException) pae.getException();
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:20,代碼來源:HdfsBlobStore.java

示例10: getAllDescendantReaderKeys

import org.apache.lucene.store.AlreadyClosedException; //導入依賴的package包/類
/**
 * Checks if the seed is an IndexReader, and if so will walk
 * the hierarchy of subReaders building up a list of the objects 
 * returned by {@code seed.getCoreCacheKey()}
 */
private List<Object> getAllDescendantReaderKeys(Object seed) {
  List<Object> all = new ArrayList<>(17); // will grow as we iter
  all.add(seed);
  for (int i = 0; i < all.size(); i++) {
    final Object obj = all.get(i);
    // TODO: We don't check closed readers here (as getTopReaderContext
    // throws AlreadyClosedException), what should we do? Reflection?
    if (obj instanceof IndexReader) {
      try {
        final List<IndexReaderContext> childs =
          ((IndexReader) obj).getContext().children();
        if (childs != null) { // it is composite reader
          for (final IndexReaderContext ctx : childs) {
            all.add(ctx.reader().getCoreCacheKey());
          }
        }
      } catch (AlreadyClosedException ace) {
        // ignore this reader
      }
    }
  }
  // need to skip the first, because it was the seed
  return all.subList(1, all.size());
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:30,代碼來源:FieldCacheSanityChecker.java

示例11: run

import org.apache.lucene.store.AlreadyClosedException; //導入依賴的package包/類
@Override
public void run() {
  int i = 0;
  while (i < 10000) {
    try {
      if (data.size() <= i) {
        sleep(1);
        continue;
      }
      final String key = "key" + i;
      final String val = "value" + i;
      final List<Document> documents = index.searchForDocuments(new TermQuery(new Term(key, val)), 10, new Sort(new SortField(key, SortField.Type.STRING)));
      if (documents.size() != 1) {
        throw new RuntimeException("Invalid number of matching documents for " + key + ", found " + documents);
      }
      ++i;
    } catch (IOException ioe) {
      error = ioe;
      break;
    } catch (InterruptedException e) {
    } catch (AlreadyClosedException ace) {
      error = ace;
      break;
    }
  }
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:27,代碼來源:TestLuceneIndexer.java

示例12: close

import org.apache.lucene.store.AlreadyClosedException; //導入依賴的package包/類
@Override
public void close() throws IOException {
    synchronized (lock) {
        if (isOpen()) {
            try {
                flush();
            } catch (AlreadyClosedException ignore) { }
        }

        if (searcherManager != null) {
            searcherManager.close();
            searcherManager = null;
        }
        if (writer != null) {
            writer.close();
            writer = null;
        }
        if (owningDirectory) {
            if (directory != null) {
                directory.close();
                directory = null;
            }
        }
    }
}
 
開發者ID:Sproutigy,項目名稱:LucenePlus,代碼行數:26,代碼來源:LuceneIndex.java

示例13: getDocument

import org.apache.lucene.store.AlreadyClosedException; //導入依賴的package包/類
/**
 *  Gets the Lucene {@link org.apache.lucene.document.Document} associated with this ResultDoc. If the index
 *  has changed since the search was conducted, this method may return an empty or incorrect Document. It is
 *  therefore best to read all Documents as soon as possible after a search if the index is being
 *  concurrently modified.
 *
 * @return    The {@link org.apache.lucene.document.Document} associated with this ResultDoc.
 */
public final Document getDocument() {
	try {
		if (_document == null)
			_document = _resultDocConfig.index.getReader().document(_docNum);
		return _document;
	} catch (AlreadyClosedException ace) {
		prtlnErr("Error retrieving document: The current IndexReader is already closed.");			
	} catch (IllegalArgumentException iae) {
		// IllegalArgumentException is thrown when index has changed since the search was performed and _docNum is no longer valid:
		prtlnErr("Error retrieving document: Lucene docID " + _docNum + " is no longer valid.");	
	} catch (Throwable e) {
		prtlnErr("Error retrieving document: " + e);
		e.printStackTrace();
	}
	
	// If all else fails, return empty document:
	return new Document();
}
 
開發者ID:NCAR,項目名稱:dls-repository-stack,代碼行數:27,代碼來源:ResultDoc.java

示例14: close

import org.apache.lucene.store.AlreadyClosedException; //導入依賴的package包/類
/**
 * Closes the handler, releases resources and flushes the recent index changes
 * to persistent storage.
 */
@Override
public synchronized void close() {
  if (isClosed) {
    throw new AlreadyClosedException("Already closed");
  }
  isClosed = true;
  try {
    nrtManager.close();
    if (analyzer != null) {
      analyzer.close();
    }
    nrtManagerReopenThread.close();
    indexWriter.close();
  } catch (IOException ex) {
    LOG.log(Level.SEVERE, "Failed to close the Lucene index", ex);
  }
  LOG.info("Successfully closed the Lucene index...");
}
 
開發者ID:jorkey,項目名稱:Wiab.pro,代碼行數:23,代碼來源:LuceneSearchImpl.java

示例15: swapSearcher

import org.apache.lucene.store.AlreadyClosedException; //導入依賴的package包/類
private void swapSearcher(final Directory dir) throws IOException {
  /*
   * opening a searcher is possibly very expensive.
   * We rather close it again if the Spellchecker was closed during
   * this operation than block access to the current searcher while opening.
   */
  final IndexSearcher indexSearcher = createSearcher(dir);
  synchronized (searcherLock) {
    if(closed){
      indexSearcher.getIndexReader().close();
      throw new AlreadyClosedException("Spellchecker has been closed");
    }
    if (searcher != null) {
      searcher.getIndexReader().close();
    }
    // set the spellindex in the sync block - ensure consistency.
    searcher = indexSearcher;
    this.spellIndex = dir;
  }
}
 
開發者ID:europeana,項目名稱:search,代碼行數:21,代碼來源:SpellChecker.java


注:本文中的org.apache.lucene.store.AlreadyClosedException類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。