All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.lucene.index.FlushPolicy Maven / Gradle / Ivy

There is a newer version: 2024.11.18751.20241128T090041Z-241100
Show newest version
/*
 * COPIED FROM APACHE LUCENE 4.7.2
 *
 * Git URL: [email protected]:apache/lucene.git, tag: releases/lucene-solr/4.7.2, path: lucene/core/src/java
 *
 * (see https://issues.apache.org/jira/browse/OAK-10786 for details)
 */

package org.apache.lucene.index;

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements. See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License. You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
import java.util.Iterator;

import org.apache.lucene.index.DocumentsWriterPerThreadPool.ThreadState;
import org.apache.lucene.store.Directory;
import org.apache.lucene.util.InfoStream;
import org.apache.lucene.util.SetOnce;

/**
 * {@link FlushPolicy} controls when segments are flushed from a RAM resident
 * internal data-structure to the {@link IndexWriter}s {@link Directory}.
 * 

* Segments are traditionally flushed by: *

    *
  • RAM consumption - configured via * {@link IndexWriterConfig#setRAMBufferSizeMB(double)}
  • *
  • Number of RAM resident documents - configured via * {@link IndexWriterConfig#setMaxBufferedDocs(int)}
  • *
* The policy also applies pending delete operations (by term and/or query), * given the threshold set in * {@link IndexWriterConfig#setMaxBufferedDeleteTerms(int)}. *

* {@link IndexWriter} consults the provided {@link FlushPolicy} to control the * flushing process. The policy is informed for each added or updated document * as well as for each delete term. Based on the {@link FlushPolicy}, the * information provided via {@link ThreadState} and * {@link DocumentsWriterFlushControl}, the {@link FlushPolicy} decides if a * {@link DocumentsWriterPerThread} needs flushing and mark it as flush-pending * via {@link DocumentsWriterFlushControl#setFlushPending}, or if deletes need * to be applied. * * @see ThreadState * @see DocumentsWriterFlushControl * @see DocumentsWriterPerThread * @see IndexWriterConfig#setFlushPolicy(FlushPolicy) */ abstract class FlushPolicy implements Cloneable { protected LiveIndexWriterConfig indexWriterConfig; protected InfoStream infoStream; /** * Called for each delete term. If this is a delete triggered due to an update * the given {@link ThreadState} is non-null. *

* Note: This method is called synchronized on the given * {@link DocumentsWriterFlushControl} and it is guaranteed that the calling * thread holds the lock on the given {@link ThreadState} */ public abstract void onDelete(DocumentsWriterFlushControl control, ThreadState state); /** * Called for each document update on the given {@link ThreadState}'s * {@link DocumentsWriterPerThread}. *

* Note: This method is called synchronized on the given * {@link DocumentsWriterFlushControl} and it is guaranteed that the calling * thread holds the lock on the given {@link ThreadState} */ public void onUpdate(DocumentsWriterFlushControl control, ThreadState state) { onInsert(control, state); onDelete(control, state); } /** * Called for each document addition on the given {@link ThreadState}s * {@link DocumentsWriterPerThread}. *

* Note: This method is synchronized by the given * {@link DocumentsWriterFlushControl} and it is guaranteed that the calling * thread holds the lock on the given {@link ThreadState} */ public abstract void onInsert(DocumentsWriterFlushControl control, ThreadState state); /** * Called by DocumentsWriter to initialize the FlushPolicy */ protected synchronized void init(LiveIndexWriterConfig indexWriterConfig) { this.indexWriterConfig = indexWriterConfig; infoStream = indexWriterConfig.getInfoStream(); } /** * Returns the current most RAM consuming non-pending {@link ThreadState} with * at least one indexed document. *

* This method will never return null */ protected ThreadState findLargestNonPendingWriter( DocumentsWriterFlushControl control, ThreadState perThreadState) { assert perThreadState.dwpt.getNumDocsInRAM() > 0; long maxRamSoFar = perThreadState.bytesUsed; // the dwpt which needs to be flushed eventually ThreadState maxRamUsingThreadState = perThreadState; assert !perThreadState.flushPending : "DWPT should have flushed"; Iterator activePerThreadsIterator = control.allActiveThreadStates(); while (activePerThreadsIterator.hasNext()) { ThreadState next = activePerThreadsIterator.next(); if (!next.flushPending) { final long nextRam = next.bytesUsed; if (nextRam > maxRamSoFar && next.dwpt.getNumDocsInRAM() > 0) { maxRamSoFar = nextRam; maxRamUsingThreadState = next; } } } assert assertMessage("set largest ram consuming thread pending on lower watermark"); return maxRamUsingThreadState; } private boolean assertMessage(String s) { if (infoStream.isEnabled("FP")) { infoStream.message("FP", s); } return true; } @Override public FlushPolicy clone() { FlushPolicy clone; try { clone = (FlushPolicy) super.clone(); } catch (CloneNotSupportedException e) { // should not happen throw new RuntimeException(e); } clone.indexWriterConfig = null; clone.infoStream = null; return clone; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy