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

org.apache.hudi.common.table.timeline.HoodieActiveTimeline 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.hudi.common.table.timeline;

import org.apache.hudi.common.model.HoodieCommitMetadata;
import org.apache.hudi.common.util.Option;
import org.apache.hudi.common.util.collection.Pair;
import org.apache.hudi.storage.StoragePath;

import java.util.Set;

/**
 * Represents the Active Timeline for the Hoodie table.
 * The timeline is not automatically reloaded on any mutation operation, clients have to manually call reload() so that
 * they can chain multiple mutations to the timeline and then call reload() once.
 * 

*

* This class can be serialized and de-serialized and on de-serialization the FileSystem is re-initialized. */ public interface HoodieActiveTimeline extends HoodieTimeline { /** * Return Valid extensions expected in active timeline. * @return */ public Set getValidExtensionsInActiveTimeline(); /** * Create a complete instant and save to storage with a completion time. * @param instant the complete instant. */ public void createCompleteInstant(HoodieInstant instant); /** * Create a pending instant and save to storage. * @param instant the pending instant. */ public void createNewInstant(HoodieInstant instant); public void createRequestedCommitWithReplaceMetadata(String instantTime, String actionType); /** * Save Completed instant in active timeline. * @param instant Instant to be saved. * @param data Metadata to be written in the instant file. */ public void saveAsComplete(HoodieInstant instant, Option data); /** * Save Completed instant in active timeline. * @param shouldLock Lock before writing to timeline. * @param instant Instant to be saved. * @param data Metadata to be written in the instant file. */ public void saveAsComplete(boolean shouldLock, HoodieInstant instant, Option data); /** * Delete Compaction requested instant file from timeline. * @param instant Instant to be deleted. */ public HoodieInstant revertToInflight(HoodieInstant instant); /** * Delete inflight instant file from timeline. * @param instant Instant to be deleted. */ public void deleteInflight(HoodieInstant instant); /** * Delete pending instant file from timeline. * @param instant Instant to be deleted. */ public void deletePending(HoodieInstant instant); /** * Delete completed rollback instant file from timeline. * @param instant Instant to be deleted. */ public void deleteCompletedRollback(HoodieInstant instant); /** * Delete empty instant file from timeline. * @param instant Instant to be deleted. */ public void deleteEmptyInstantIfExists(HoodieInstant instant); /** * Delete Compaction requested instant file from timeline. * @param instant Instant to be deleted. */ public void deleteCompactionRequested(HoodieInstant instant); /** * Note: This method should only be used in the case that delete requested/inflight instant or empty clean instant, * and completed commit instant in an archive operation. */ public void deleteInstantFileIfExists(HoodieInstant instant); /** * Returns most recent instant having valid schema in its {@link HoodieCommitMetadata} */ public Option> getLastCommitMetadataWithValidSchema(); /** * Get the last instant with valid data, and convert this to HoodieCommitMetadata */ public Option> getLastCommitMetadataWithValidData(); /** * Read cleaner Info from instant file. * @param instant Instant to read from. * @return */ public Option readCleanerInfoAsBytes(HoodieInstant instant); /** * Read rollback info from instant file. * @param instant Instant to read from. * @return */ public Option readRollbackInfoAsBytes(HoodieInstant instant); /** * Read Restore info from instant file. * @param instant Instant to read from. * @return */ public Option readRestoreInfoAsBytes(HoodieInstant instant); //----------------------------------------------------------------- // BEGIN - COMPACTION RELATED META-DATA MANAGEMENT. //----------------------------------------------------------------- /** * Read compaction Plan from instant file. * @param instant Instant to read from. * @return */ public Option readCompactionPlanAsBytes(HoodieInstant instant); /** * Read Index Plan from instant file. * @param instant Instant to read from. * @return */ public Option readIndexPlanAsBytes(HoodieInstant instant); /** * Revert instant state from inflight to requested. * * @param inflightInstant Inflight Instant * @return requested instant */ public HoodieInstant revertInstantFromInflightToRequested(HoodieInstant inflightInstant); /** * TODO: This method is not needed, since log compaction plan is not a immutable plan. * Revert logcompaction State from inflight to requested. * * @param inflightInstant Inflight Instant * @return requested instant */ public HoodieInstant revertLogCompactionInflightToRequested(HoodieInstant inflightInstant); /** * Transition Compaction State from requested to inflight. * * @param requestedInstant Requested instant * @return inflight instant */ public HoodieInstant transitionCompactionRequestedToInflight(HoodieInstant requestedInstant); /** * Transition LogCompaction State from requested to inflight. * * @param requestedInstant Requested instant * @return inflight instant */ public HoodieInstant transitionLogCompactionRequestedToInflight(HoodieInstant requestedInstant); /** * Transition Compaction State from inflight to Committed. * * @param shouldLock Whether to hold the lock when performing transition * @param inflightInstant Inflight instant * @param data Extra Metadata * @return commit instant */ public HoodieInstant transitionCompactionInflightToComplete(boolean shouldLock, HoodieInstant inflightInstant, Option data); /** * Transition Log Compaction State from inflight to Committed. * * @param shouldLock Whether to hold the lock when performing transition * @param inflightInstant Inflight instant * @param data Extra Metadata * @return commit instant */ public HoodieInstant transitionLogCompactionInflightToComplete(boolean shouldLock, HoodieInstant inflightInstant, Option data); //----------------------------------------------------------------- // END - COMPACTION RELATED META-DATA MANAGEMENT //----------------------------------------------------------------- /** * Transition Clean State from inflight to Committed. * * @param shouldLock Whether to hold the lock when performing transition * @param inflightInstant Inflight instant * @param data Extra Metadata * @return commit instant */ public HoodieInstant transitionCleanInflightToComplete(boolean shouldLock, HoodieInstant inflightInstant, Option data); /** * Transition Clean State from requested to inflight. * * @param requestedInstant requested instant * @param data Optional data to be stored * @return commit instant */ public HoodieInstant transitionCleanRequestedToInflight(HoodieInstant requestedInstant, Option data); /** * Transition Rollback State from inflight to Committed. * * @param shouldLock Whether to hold the lock when performing transition * @param inflightInstant Inflight instant * @param data Extra Metadata * @return commit instant */ public HoodieInstant transitionRollbackInflightToComplete(boolean shouldLock, HoodieInstant inflightInstant, Option data); /** * Transition Rollback State from requested to inflight. * * @param requestedInstant requested instant * @return commit instant */ public HoodieInstant transitionRollbackRequestedToInflight(HoodieInstant requestedInstant); /** * Transition Restore State from requested to inflight. * * @param requestedInstant requested instant * @return commit instant */ public HoodieInstant transitionRestoreRequestedToInflight(HoodieInstant requestedInstant); /** * Transition replace requested file to replace inflight. * * @param requestedInstant Requested instant * @param data Extra Metadata * @return inflight instant */ public HoodieInstant transitionReplaceRequestedToInflight(HoodieInstant requestedInstant, Option data); /** * Transition cluster requested file to cluster inflight. * * @param requestedInstant Requested instant * @param data Extra Metadata * @return inflight instant */ public HoodieInstant transitionClusterRequestedToInflight(HoodieInstant requestedInstant, Option data); /** * Transition replace inflight to Committed. * * @param shouldLock Whether to hold the lock when performing transition * @param inflightInstant Inflight instant * @param data Extra Metadata * @return commit instant */ public HoodieInstant transitionReplaceInflightToComplete(boolean shouldLock, HoodieInstant inflightInstant, Option data); /** * Transition cluster inflight to replace committed. * * @param shouldLock Whether to hold the lock when performing transition * @param inflightInstant Inflight instant * @param data Extra Metadata * @return commit instant */ public HoodieInstant transitionClusterInflightToComplete(boolean shouldLock, HoodieInstant inflightInstant, Option data); /** * Save Restore requested instant with metadata. * @param commitType Instant type. * @param inFlightInstant Instant timestamp. */ public void transitionRequestedToInflight(String commitType, String inFlightInstant); /** * Save Restore requested instant with metadata. * @param requested Instant to save. * @param content Metadata to be stored in instant file. */ public void transitionRequestedToInflight(HoodieInstant requested, Option content); /** * Save Restore requested instant with metadata. * @param requested Instant to save. * @param content Metadata to be stored in instant file. */ public void transitionRequestedToInflight(HoodieInstant requested, Option content, boolean allowRedundantTransitions); /** * Save Compaction requested instant with metadata. * @param instant Instant to save. * @param content Metadata to be stored in instant file. */ public void saveToCompactionRequested(HoodieInstant instant, Option content); /** * Save Compaction requested instant with metadata. * @param instant Instant to save. * @param content Metadata to be stored in instant file. * @param overwrite Overwrite existing instant file. */ public void saveToCompactionRequested(HoodieInstant instant, Option content, boolean overwrite); /** * Save Log Compaction requested instant with metadata. * @param instant Instant to save. * @param content Metadata to be stored in instant file. */ public void saveToLogCompactionRequested(HoodieInstant instant, Option content); /** * Save Log Compaction requested instant with metadata. * @param instant Instant to save. * @param content Metadata to be stored in instant file. * @param overwrite Overwrite existing instant file. */ public void saveToLogCompactionRequested(HoodieInstant instant, Option content, boolean overwrite); /** * Save pending replace instant with metadata. * @param instant Instant to save. * @param content Metadata to be stored in instant file. */ public void saveToPendingReplaceCommit(HoodieInstant instant, Option content); /** * Save pending cluster instant with metadata. * @param instant Instant to save. * @param content Metadata to be stored in instant file. */ public void saveToPendingClusterCommit(HoodieInstant instant, Option content); /** * Save clean requested instant with metadata. * @param instant Instant to save. * @param content Metadata to be stored in instant file. */ public void saveToCleanRequested(HoodieInstant instant, Option content); /** * Save rollback requested instant with metadata. * @param instant Instant to save. * @param content Metadata to be stored in instant file. */ public void saveToRollbackRequested(HoodieInstant instant, Option content); /** * Save Restore requested instant with metadata. * @param instant Instant to save. * @param content Metadata to be stored in instant file. */ public void saveToRestoreRequested(HoodieInstant instant, Option content); /** * Transition index instant state from requested to inflight. * * @param requestedInstant Inflight Instant * @return inflight instant */ public HoodieInstant transitionIndexRequestedToInflight(HoodieInstant requestedInstant, Option data); /** * Transition index instant state from inflight to completed. * * @param shouldLock Whether to hold the lock when performing transition * @param inflightInstant Inflight Instant * @return completed instant */ public HoodieInstant transitionIndexInflightToComplete(boolean shouldLock, HoodieInstant inflightInstant, Option data); /** * Revert index instant state from inflight to requested. * @param inflightInstant Inflight Instant * @return requested instant */ public HoodieInstant revertIndexInflightToRequested(HoodieInstant inflightInstant); /** * Save content for inflight/requested index instant. */ public void saveToPendingIndexAction(HoodieInstant instant, Option content); /** * Reloads timeline from storage * @return */ public HoodieActiveTimeline reload(); /** * Copies instant file from active timeline to destination directory. * @param instant Instant to copy. * @param dstDir Destination location. */ public void copyInstant(HoodieInstant instant, StoragePath dstDir); /** * Valid Extensions in active timeline. * @return */ Set getValidExtensions(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy