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

org.apache.flink.runtime.checkpoint.CompletedCheckpoint Maven / Gradle / Ivy

The newest version!
/*
 * 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.flink.runtime.checkpoint;

import org.apache.flink.api.common.JobID;
import org.apache.flink.api.java.tuple.Tuple2;
import org.apache.flink.runtime.jobgraph.JobStatus;
import org.apache.flink.runtime.jobgraph.OperatorID;
import org.apache.flink.runtime.state.CompletedCheckpointStorageLocation;
import org.apache.flink.runtime.state.SharedStateRegistry;
import org.apache.flink.runtime.state.StateUtil;
import org.apache.flink.runtime.state.StreamStateHandle;
import org.apache.flink.util.ExceptionUtils;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import javax.annotation.Nullable;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import static org.apache.flink.util.Preconditions.checkArgument;
import static org.apache.flink.util.Preconditions.checkNotNull;

/**
 * A CompletedCheckpoint describes a checkpoint after all required tasks acknowledged it (with their state)
 * and that is considered successful. The CompletedCheckpoint class contains all the metadata of the
 * checkpoint, i.e., checkpoint ID, timestamps, and the handles to all states that are part of the
 * checkpoint.
 *
 * 

Size the CompletedCheckpoint Instances

* *

In most cases, the CompletedCheckpoint objects are very small, because the handles to the checkpoint * states are only pointers (such as file paths). However, the some state backend implementations may * choose to store some payload data directly with the metadata (for example to avoid many small files). * If those thresholds are increased to large values, the memory consumption of the CompletedCheckpoint * objects can be significant. * *

Metadata Persistence

* *

The metadata of the CompletedCheckpoint is also persisted in an external storage * system. Checkpoints have an external pointer, which points to the metadata. For example * when storing a checkpoint in a file system, that pointer is the file path to the checkpoint's folder * or the metadata file. For a state backend that stores metadata in database tables, the pointer * could be the table name and row key. The pointer is encoded as a String. */ public class CompletedCheckpoint implements Serializable { private static final Logger LOG = LoggerFactory.getLogger(CompletedCheckpoint.class); private static final long serialVersionUID = -8360248179615702014L; // ------------------------------------------------------------------------ /** The ID of the job that the checkpoint belongs to. */ private final JobID job; /** The ID (logical timestamp) of the checkpoint. */ private final long checkpointID; /** The timestamp when the checkpoint was triggered. */ private final long timestamp; /** The duration of the checkpoint (completion timestamp - trigger timestamp). */ private final long duration; /** States of the different operator groups belonging to this checkpoint. */ private final Map operatorStates; /** Properties for this checkpoint. */ private final CheckpointProperties props; /** States that were created by a hook on the master (in the checkpoint coordinator). */ private final Collection masterHookStates; /** The location where the checkpoint is stored. */ private final CompletedCheckpointStorageLocation storageLocation; /** The state handle to the externalized meta data. */ private final StreamStateHandle metadataHandle; /** External pointer to the completed checkpoint (for example file path). */ private final String externalPointer; /** Optional stats tracker callback for discard. */ @Nullable private transient volatile CompletedCheckpointStats.DiscardCallback discardCallback; // ------------------------------------------------------------------------ public CompletedCheckpoint( JobID job, long checkpointID, long timestamp, long completionTimestamp, Map operatorStates, @Nullable Collection masterHookStates, CheckpointProperties props, CompletedCheckpointStorageLocation storageLocation) { checkArgument(checkpointID >= 0); checkArgument(timestamp >= 0); checkArgument(completionTimestamp >= 0); this.job = checkNotNull(job); this.checkpointID = checkpointID; this.timestamp = timestamp; this.duration = completionTimestamp - timestamp; // we create copies here, to make sure we have no shared mutable // data structure with the "outside world" this.operatorStates = new HashMap<>(checkNotNull(operatorStates)); this.masterHookStates = masterHookStates == null || masterHookStates.isEmpty() ? Collections.emptyList() : new ArrayList<>(masterHookStates); this.props = checkNotNull(props); this.storageLocation = checkNotNull(storageLocation); this.metadataHandle = storageLocation.getMetadataHandle(); this.externalPointer = storageLocation.getExternalPointer(); } // ------------------------------------------------------------------------ // Properties // ------------------------------------------------------------------------ public JobID getJobId() { return job; } public long getCheckpointID() { return checkpointID; } public long getTimestamp() { return timestamp; } public long getDuration() { return duration; } public CheckpointProperties getProperties() { return props; } public Map getOperatorStates() { return operatorStates; } public Collection getMasterHookStates() { return Collections.unmodifiableCollection(masterHookStates); } public StreamStateHandle getMetadataHandle() { return metadataHandle; } public String getExternalPointer() { return externalPointer; } public long getStateSize() { long result = 0L; for (OperatorState operatorState : operatorStates.values()) { result += operatorState.getStateSize(); } return result; } // ------------------------------------------------------------------------ // Shared State // ------------------------------------------------------------------------ /** * Register all shared states in the given registry. This is method is called * before the checkpoint is added into the store. * * @param sharedStateRegistry The registry where shared states are registered */ public void registerSharedStatesAfterRestored(SharedStateRegistry sharedStateRegistry) { sharedStateRegistry.registerAll(operatorStates.values()); } // ------------------------------------------------------------------------ // Discard and Dispose // ------------------------------------------------------------------------ public void discardOnFailedStoring() throws Exception { doDiscard(); } public boolean discardOnSubsume() throws Exception { if (props.discardOnSubsumed()) { doDiscard(); return true; } return false; } public boolean discardOnShutdown(JobStatus jobStatus) throws Exception { if (jobStatus == JobStatus.FINISHED && props.discardOnJobFinished() || jobStatus == JobStatus.CANCELED && props.discardOnJobCancelled() || jobStatus == JobStatus.FAILED && props.discardOnJobFailed() || jobStatus == JobStatus.SUSPENDED && props.discardOnJobSuspended()) { doDiscard(); return true; } else { LOG.info("Checkpoint with ID {} at '{}' not discarded.", checkpointID, externalPointer); return false; } } private void doDiscard() throws Exception { LOG.trace("Executing discard procedure for {}.", this); try { // collect exceptions and continue cleanup Exception exception = null; // drop the metadata try { metadataHandle.discardState(); } catch (Exception e) { exception = e; } // discard private state objects try { StateUtil.bestEffortDiscardAllStateObjects(operatorStates.values()); } catch (Exception e) { exception = ExceptionUtils.firstOrSuppressed(e, exception); } // discard location as a whole try { storageLocation.disposeStorageLocation(); } catch (Exception e) { exception = ExceptionUtils.firstOrSuppressed(e, exception); } if (exception != null) { throw exception; } } finally { operatorStates.clear(); // to be null-pointer safe, copy reference to stack CompletedCheckpointStats.DiscardCallback discardCallback = this.discardCallback; if (discardCallback != null) { discardCallback.notifyDiscardedCheckpoint(); } } } // ------------------------------------------------------------------------ // Miscellaneous // ------------------------------------------------------------------------ public static boolean checkpointsMatch( Collection first, Collection second) { if (first.size() != second.size()) { return false; } List> firstInterestingFields = new ArrayList<>(first.size()); for (CompletedCheckpoint checkpoint : first) { firstInterestingFields.add( new Tuple2<>(checkpoint.getCheckpointID(), checkpoint.getJobId())); } List> secondInterestingFields = new ArrayList<>(second.size()); for (CompletedCheckpoint checkpoint : second) { secondInterestingFields.add( new Tuple2<>(checkpoint.getCheckpointID(), checkpoint.getJobId())); } return firstInterestingFields.equals(secondInterestingFields); } /** * Sets the callback for tracking when this checkpoint is discarded. * * @param discardCallback Callback to call when the checkpoint is discarded. */ void setDiscardCallback(@Nullable CompletedCheckpointStats.DiscardCallback discardCallback) { this.discardCallback = discardCallback; } @Override public String toString() { return String.format("Checkpoint %d @ %d for %s", checkpointID, timestamp, job); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy