com.facebook.presto.orc.cache.OrcCacheConfig Maven / Gradle / Ivy
/*
* Licensed 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 com.facebook.presto.orc.cache;
import com.facebook.airlift.configuration.Config;
import com.facebook.airlift.configuration.ConfigDescription;
import io.airlift.units.DataSize;
import io.airlift.units.Duration;
import io.airlift.units.MinDataSize;
import io.airlift.units.MinDuration;
import static com.facebook.presto.orc.OrcDataSourceUtils.EXPECTED_FOOTER_SIZE_IN_BYTES;
import static io.airlift.units.DataSize.Unit.BYTE;
import static java.util.concurrent.TimeUnit.SECONDS;
public class OrcCacheConfig
{
private boolean fileTailCacheEnabled;
private DataSize fileTailCacheSize = new DataSize(0, BYTE);
private Duration fileTailCacheTtlSinceLastAccess = new Duration(0, SECONDS);
private boolean stripeMetadataCacheEnabled;
private DataSize stripeFooterCacheSize = new DataSize(0, BYTE);
private Duration stripeFooterCacheTtlSinceLastAccess = new Duration(0, SECONDS);
private DataSize stripeStreamCacheSize = new DataSize(0, BYTE);
private Duration stripeStreamCacheTtlSinceLastAccess = new Duration(0, SECONDS);
private boolean dwrfStripeCacheEnabled;
private DataSize expectedFileTailSize = new DataSize(EXPECTED_FOOTER_SIZE_IN_BYTES, BYTE);
public boolean isFileTailCacheEnabled()
{
return fileTailCacheEnabled;
}
@Config("orc.file-tail-cache-enabled")
@ConfigDescription("Enable cache for orc file tail")
public OrcCacheConfig setFileTailCacheEnabled(boolean fileTailCacheEnabled)
{
this.fileTailCacheEnabled = fileTailCacheEnabled;
return this;
}
@MinDataSize("0B")
public DataSize getFileTailCacheSize()
{
return fileTailCacheSize;
}
@Config("orc.file-tail-cache-size")
@ConfigDescription("Size of the orc file tail cache")
public OrcCacheConfig setFileTailCacheSize(DataSize fileTailCacheSize)
{
this.fileTailCacheSize = fileTailCacheSize;
return this;
}
@MinDuration("0s")
public Duration getFileTailCacheTtlSinceLastAccess()
{
return fileTailCacheTtlSinceLastAccess;
}
@Config("orc.file-tail-cache-ttl-since-last-access")
@ConfigDescription("Time-to-live for orc file tail cache entry after last access")
public OrcCacheConfig setFileTailCacheTtlSinceLastAccess(Duration fileTailCacheTtlSinceLastAccess)
{
this.fileTailCacheTtlSinceLastAccess = fileTailCacheTtlSinceLastAccess;
return this;
}
public boolean isStripeMetadataCacheEnabled()
{
return stripeMetadataCacheEnabled;
}
@Config("orc.stripe-metadata-cache-enabled")
@ConfigDescription("Enable cache for stripe metadata")
public OrcCacheConfig setStripeMetadataCacheEnabled(boolean stripeMetadataCacheEnabled)
{
this.stripeMetadataCacheEnabled = stripeMetadataCacheEnabled;
return this;
}
@MinDataSize("0B")
public DataSize getStripeFooterCacheSize()
{
return stripeFooterCacheSize;
}
@Config("orc.stripe-footer-cache-size")
@ConfigDescription("Size of the stripe footer cache")
public OrcCacheConfig setStripeFooterCacheSize(DataSize stripeFooterCacheSize)
{
this.stripeFooterCacheSize = stripeFooterCacheSize;
return this;
}
@MinDuration("0s")
public Duration getStripeFooterCacheTtlSinceLastAccess()
{
return stripeFooterCacheTtlSinceLastAccess;
}
@Config("orc.stripe-footer-cache-ttl-since-last-access")
@ConfigDescription("Time-to-live for stripe footer cache entry after last access")
public OrcCacheConfig setStripeFooterCacheTtlSinceLastAccess(Duration stripeFooterCacheTtlSinceLastAccess)
{
this.stripeFooterCacheTtlSinceLastAccess = stripeFooterCacheTtlSinceLastAccess;
return this;
}
@MinDataSize("0B")
public DataSize getStripeStreamCacheSize()
{
return stripeStreamCacheSize;
}
@Config("orc.stripe-stream-cache-size")
@ConfigDescription("Size of the stripe stream cache")
public OrcCacheConfig setStripeStreamCacheSize(DataSize stripeStreamCacheSize)
{
this.stripeStreamCacheSize = stripeStreamCacheSize;
return this;
}
@MinDuration("0s")
public Duration getStripeStreamCacheTtlSinceLastAccess()
{
return stripeStreamCacheTtlSinceLastAccess;
}
@Config("orc.stripe-stream-cache-ttl-since-last-access")
@ConfigDescription("Time-to-live for stripe stream cache entry after last access")
public OrcCacheConfig setStripeStreamCacheTtlSinceLastAccess(Duration stripeStreamCacheTtlSinceLastAccess)
{
this.stripeStreamCacheTtlSinceLastAccess = stripeStreamCacheTtlSinceLastAccess;
return this;
}
public boolean isDwrfStripeCacheEnabled()
{
return dwrfStripeCacheEnabled;
}
// DWRF format duplicates the stripe footer and index streams, and stores them before the footer.
// DWRF StripeCache will reduce small IO's used to read the stripe footer and index streams.
// Note when enabling dwrf stripe cache, increase the tail size so that footer and stripe cache
// can be read in the same IO.
@Config("orc.dwrf-stripe-cache-enabled")
@ConfigDescription("Check DWRF stripe cache to look for stripe footers and index streams")
public OrcCacheConfig setDwrfStripeCacheEnabled(boolean dwrfStripeCacheEnabled)
{
this.dwrfStripeCacheEnabled = dwrfStripeCacheEnabled;
return this;
}
@MinDataSize("256B")
public DataSize getExpectedFileTailSize()
{
return expectedFileTailSize;
}
@Config("orc.expected-file-tail-size")
@ConfigDescription("Expected size of the file tail. This value should be increased to read StripeCache and footer in one IO")
public OrcCacheConfig setExpectedFileTailSize(DataSize expectedFileTailSize)
{
this.expectedFileTailSize = expectedFileTailSize;
return this;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy