
org.apache.jackrabbit.oak.segment.compaction.SegmentGCOptions Maven / Gradle / Ivy
/*
* 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.
*/
package org.apache.jackrabbit.oak.segment.compaction;
import static com.google.common.base.Preconditions.checkArgument;
/**
* This class holds configuration options for segment store revision gc.
*/
public class SegmentGCOptions {
/**
* Default value for {@link #isPaused()}
*/
public static final boolean PAUSE_DEFAULT = false;
/**
* Default value for {@link #getMemoryThreshold()}
*/
public static final byte MEMORY_THRESHOLD_DEFAULT = 5;
/**
* Default value for {@link #getGainThreshold()}
*/
public static final byte GAIN_THRESHOLD_DEFAULT = 10;
/**
* Default value for {@link #getRetryCount()}
*/
public static final int RETRY_COUNT_DEFAULT = 5;
/**
* Default value for {@link #getForceAfterFail()}
*/
public static final boolean FORCE_AFTER_FAIL_DEFAULT = false;
/**
* Default value for {@link #getLockWaitTime()}
*/
public static final int LOCK_WAIT_TIME_DEFAULT = 60000;
/**
* Default value for {@link #getRetainedGenerations()}
*/
public static final int RETAINED_GENERATIONS_DEFAULT = 2;
private boolean paused = PAUSE_DEFAULT;
private int memoryThreshold = MEMORY_THRESHOLD_DEFAULT;
private int gainThreshold = GAIN_THRESHOLD_DEFAULT;
private int retryCount = RETRY_COUNT_DEFAULT;
private boolean forceAfterFail = FORCE_AFTER_FAIL_DEFAULT;
private int lockWaitTime = LOCK_WAIT_TIME_DEFAULT;
private int retainedGenerations = RETAINED_GENERATIONS_DEFAULT;
private boolean offline = false;
private boolean ocBinDeduplication = Boolean
.getBoolean("oak.segment.compaction.binaryDeduplication");
private long ocBinMaxSize = Long.getLong(
"oak.segment.compaction.binaryDeduplicationMaxSize",
100 * 1024 * 1024);
public SegmentGCOptions(boolean paused, int memoryThreshold, int gainThreshold,
int retryCount, boolean forceAfterFail, int lockWaitTime) {
this.paused = paused;
this.memoryThreshold = memoryThreshold;
this.gainThreshold = gainThreshold;
this.retryCount = retryCount;
this.forceAfterFail = forceAfterFail;
this.lockWaitTime = lockWaitTime;
}
public SegmentGCOptions() {
this(PAUSE_DEFAULT, MEMORY_THRESHOLD_DEFAULT, GAIN_THRESHOLD_DEFAULT,
RETRY_COUNT_DEFAULT, FORCE_AFTER_FAIL_DEFAULT, LOCK_WAIT_TIME_DEFAULT);
}
/**
* Default options: {@link #PAUSE_DEFAULT}, {@link #MEMORY_THRESHOLD_DEFAULT},
* {@link #GAIN_THRESHOLD_DEFAULT}, {@link #RETRY_COUNT_DEFAULT},
* {@link #FORCE_AFTER_FAIL_DEFAULT}, {@link #LOCK_WAIT_TIME_DEFAULT}.
*/
public static SegmentGCOptions defaultGCOptions() {
return new SegmentGCOptions();
}
/**
* @return {@code true} iff revision gc is paused.
*/
public boolean isPaused() {
return paused;
}
/**
* Set revision gc to paused.
* @param paused
* @return this instance
*/
public SegmentGCOptions setPaused(boolean paused) {
this.paused = paused;
return this;
}
/**
* @return the memory threshold below which revision gc will not run.
*/
public int getMemoryThreshold() {
return memoryThreshold;
}
/**
* Set the memory threshold below which revision gc will not run.
* @param memoryThreshold
* @return this instance
*/
public SegmentGCOptions setMemoryThreshold(int memoryThreshold) {
this.memoryThreshold = memoryThreshold;
return this;
}
/**
* Get the gain estimate threshold beyond which revision gc should run
* @return gainThreshold
*/
public int getGainThreshold() {
return gainThreshold;
}
/**
* Set the revision gain estimate threshold beyond which revision gc should run
* @param gainThreshold
* @return this instance
*/
public SegmentGCOptions setGainThreshold(int gainThreshold) {
this.gainThreshold = gainThreshold;
return this;
}
/**
* Get the number of tries to compact concurrent commits on top of already
* compacted commits
* @return retry count
*/
public int getRetryCount() {
return retryCount;
}
/**
* Set the number of tries to compact concurrent commits on top of already
* compacted commits
* @param retryCount
* @return this instance
*/
public SegmentGCOptions setRetryCount(int retryCount) {
this.retryCount = retryCount;
return this;
}
/**
* Get whether or not to force compact concurrent commits on top of already
* compacted commits after the maximum number of retries has been reached.
* Force committing tries to exclusively write lock the node store.
* @return {@code true} if force commit is on, {@code false} otherwise
*/
public boolean getForceAfterFail() {
return forceAfterFail;
}
/**
* Set whether or not to force compact concurrent commits on top of already
* compacted commits after the maximum number of retries has been reached.
* Force committing tries to exclusively write lock the node store.
* @param forceAfterFail
* @return this instance
*/
public SegmentGCOptions setForceAfterFail(boolean forceAfterFail) {
this.forceAfterFail = forceAfterFail;
return this;
}
/**
* Get the time to wait for the lock when force compacting.
* See {@link #setForceAfterFail(boolean)}
* @return lock wait time in seconds.
*/
public int getLockWaitTime() {
return lockWaitTime;
}
/**
* Set the time to wait for the lock when force compacting.
* @param lockWaitTime lock wait time in seconds
* @return
* @return this instance
*/
public SegmentGCOptions setLockWaitTime(int lockWaitTime) {
this.lockWaitTime = lockWaitTime;
return this;
}
/**
* Number of segment generations to retain.
* @see #setRetainedGenerations(int)
* @return number of gc generations.
*/
public int getRetainedGenerations() {
return retainedGenerations;
}
/**
* Set the number of segment generations to retain: each compaction run creates
* a new segment generation. {@code retainGenerations} determines how many of
* those generations are retained during cleanup.
*
* @param retainedGenerations number of generations to retain. Must be {@code >= 2}.
* @return this instance
* @throws IllegalArgumentException if {@code retainGenerations < 2}
*/
public SegmentGCOptions setRetainedGenerations(int retainedGenerations) {
checkArgument(retainedGenerations > 1,
"RetainedGenerations must not be below 2. Got %s", retainedGenerations);
this.retainedGenerations = retainedGenerations;
return this;
}
@Override
public String toString() {
if (offline) {
return getClass().getSimpleName() + "{" +
"offline=" + offline +
", retainedGenerations=" + retainedGenerations +
", ocBinDeduplication=" + ocBinDeduplication +
", ocBinMaxSize=" + ocBinMaxSize + "}";
} else {
return getClass().getSimpleName() + "{" +
"paused=" + paused +
", memoryThreshold=" + memoryThreshold +
", gainThreshold=" + gainThreshold +
", retryCount=" + retryCount +
", forceAfterFail=" + forceAfterFail +
", lockWaitTime=" + lockWaitTime +
", retainedGenerations=" + retainedGenerations + "}";
}
}
/**
* Check if the approximate repository size is getting too big compared with
* the available space on disk.
*
* @param repositoryDiskSpace Approximate size of the disk space occupied by
* the repository.
* @param availableDiskSpace Currently available disk space.
* @return {@code true} if the available disk space is considered enough for
* normal repository operations.
*/
public boolean isDiskSpaceSufficient(long repositoryDiskSpace, long availableDiskSpace) {
return availableDiskSpace > 0.25 * repositoryDiskSpace;
}
public boolean isOffline() {
return offline;
}
/**
* Enables the offline compaction mode, allowing for certain optimizations,
* like reducing the retained generation to 1.
* @return this instance
*/
public SegmentGCOptions setOffline() {
this.offline = true;
this.retainedGenerations = 1;
return this;
}
/**
* Offline compaction only. Enables content based de-duplication of
* binaries. Involves a fair amount of I/O when reading/comparing
* potentially equal blobs. set via the
* 'oak.segment.compaction.binaryDeduplication' system property
* @return this instance.
*/
public SegmentGCOptions withBinaryDeduplication() {
this.ocBinDeduplication = true;
return this;
}
public boolean isBinaryDeduplication() {
return this.ocBinDeduplication;
}
/**
* Offline compaction only. Set the upper bound for the content based
* de-duplication checks.
* @param binMaxSize
* @return this instance
*/
public SegmentGCOptions setBinaryDeduplicationMaxSize(long binMaxSize) {
this.ocBinMaxSize = binMaxSize;
return this;
}
public long getBinaryDeduplicationMaxSize() {
return this.ocBinMaxSize;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy