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

org.apache.flink.runtime.checkpoint.PendingCheckpointStats 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.flink.runtime.checkpoint;

import org.apache.flink.runtime.jobgraph.JobVertexID;

import javax.annotation.Nullable;

import java.util.HashMap;
import java.util.Map;

import static java.util.stream.Collectors.toConcurrentMap;

/**
 * Statistics for a pending checkpoint that is still in progress.
 *
 * 

This is the starting point for all checkpoint tracking. The life cycle of instances of this * class is tightly coupled to a {@link PendingCheckpoint} instance, which forwards statistics about * acknowledged subtasks via {@link #reportSubtaskStats(JobVertexID, SubtaskStateStats)}. * *

Depending on whether the {@link PendingCheckpoint} is finalized successfully or aborted, we * replace ourselves with a {@link CompletedCheckpointStats} or {@link FailedCheckpointStats} and * notify the {@link CheckpointStatsTracker}. * *

The statistics gathered here are all live updated. */ public class PendingCheckpointStats extends AbstractCheckpointStats { private static final long serialVersionUID = -973959257699390327L; /** The current number of acknowledged subtasks. */ private volatile int currentNumAcknowledgedSubtasks; /** Current checkpoint state size over all collected subtasks. */ private volatile long currentStateSize; private volatile long currentCheckpointedSize; private volatile long currentProcessedData; private volatile long currentPersistedData; private volatile boolean unalignedCheckpoint; /** Stats of the latest acknowledged subtask. */ private volatile SubtaskStateStats latestAcknowledgedSubtask; /** * Creates a tracker for a {@link PendingCheckpoint}. * * @param checkpointId ID of the checkpoint. * @param triggerTimestamp Timestamp when the checkpoint was triggered. * @param props Checkpoint properties of the checkpoint. * @param taskStats Task stats for each involved operator. */ PendingCheckpointStats( long checkpointId, long triggerTimestamp, CheckpointProperties props, Map taskStats) { this( checkpointId, triggerTimestamp, props, taskStats.values().stream().mapToInt(i -> i).sum(), taskStats.entrySet().stream() .collect( toConcurrentMap( Map.Entry::getKey, e -> new TaskStateStats(e.getKey(), e.getValue())))); } /** * Creates a tracker for a {@link PendingCheckpoint}. * * @param checkpointId ID of the checkpoint. * @param triggerTimestamp Timestamp when the checkpoint was triggered. * @param props Checkpoint properties of the checkpoint. * @param totalSubtaskCount Total number of subtasks for the checkpoint. * @param taskStats Task stats for each involved operator. */ PendingCheckpointStats( long checkpointId, long triggerTimestamp, CheckpointProperties props, int totalSubtaskCount, Map taskStats) { this( checkpointId, triggerTimestamp, props, totalSubtaskCount, 0, taskStats, 0, 0, 0, 0, false, null); } PendingCheckpointStats( long checkpointId, long triggerTimestamp, CheckpointProperties props, int totalSubtaskCount, int acknowledgedSubtaskCount, Map taskStats, long currentCheckpointedSize, long currentStateSize, long processedData, long persistedData, boolean unalignedCheckpoint, @Nullable SubtaskStateStats latestAcknowledgedSubtask) { super(checkpointId, triggerTimestamp, props, totalSubtaskCount, taskStats); this.currentCheckpointedSize = currentCheckpointedSize; this.currentStateSize = currentStateSize; this.currentProcessedData = processedData; this.currentPersistedData = persistedData; this.unalignedCheckpoint = unalignedCheckpoint; this.latestAcknowledgedSubtask = latestAcknowledgedSubtask; this.currentNumAcknowledgedSubtasks = acknowledgedSubtaskCount; } @Override public CheckpointStatsStatus getStatus() { return CheckpointStatsStatus.IN_PROGRESS; } @Override public int getNumberOfAcknowledgedSubtasks() { return currentNumAcknowledgedSubtasks; } @Override public long getStateSize() { return currentStateSize; } @Override public long getCheckpointedSize() { return currentCheckpointedSize; } @Override public long getProcessedData() { return currentProcessedData; } @Override public long getPersistedData() { return currentPersistedData; } @Override public boolean isUnalignedCheckpoint() { return unalignedCheckpoint; } @Override public SubtaskStateStats getLatestAcknowledgedSubtaskStats() { return latestAcknowledgedSubtask; } // ------------------------------------------------------------------------ // Callbacks from the PendingCheckpoint instance // ------------------------------------------------------------------------ /** * Reports statistics for a single subtask. * * @param jobVertexId ID of the task/operator the subtask belongs to. * @param subtask The statistics for the subtask. * @return true if successfully reported or false otherwise. */ boolean reportSubtaskStats(JobVertexID jobVertexId, SubtaskStateStats subtask) { TaskStateStats taskStateStats = taskStats.get(jobVertexId); if (taskStateStats != null && taskStateStats.reportSubtaskStats(subtask)) { if (subtask.isCompleted()) { currentNumAcknowledgedSubtasks++; latestAcknowledgedSubtask = subtask; } currentCheckpointedSize += subtask.getCheckpointedSize(); currentStateSize += subtask.getStateSize(); long processedData = subtask.getProcessedData(); if (processedData > 0) { currentProcessedData += processedData; } long persistedData = subtask.getPersistedData(); if (persistedData > 0) { currentPersistedData += persistedData; } unalignedCheckpoint |= subtask.getUnalignedCheckpoint(); return true; } else { return false; } } CompletedCheckpointStats toCompletedCheckpointStats(String externalPointer) { return new CompletedCheckpointStats( checkpointId, triggerTimestamp, props, numberOfSubtasks, new HashMap<>(taskStats), currentNumAcknowledgedSubtasks, currentCheckpointedSize, currentStateSize, currentProcessedData, currentPersistedData, unalignedCheckpoint, latestAcknowledgedSubtask, externalPointer); } /** * Reports a failed pending checkpoint. * * @param failureTimestamp Timestamp of the failure. * @param cause Optional cause of the failure. */ FailedCheckpointStats toFailedCheckpoint(long failureTimestamp, @Nullable Throwable cause) { return new FailedCheckpointStats( checkpointId, triggerTimestamp, props, numberOfSubtasks, new HashMap<>(taskStats), currentNumAcknowledgedSubtasks, currentCheckpointedSize, currentStateSize, currentProcessedData, currentPersistedData, unalignedCheckpoint, failureTimestamp, latestAcknowledgedSubtask, cause); } @Override public String toString() { return "PendingCheckpoint(id=" + getCheckpointId() + ")"; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy