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

org.apache.spark.executor.ExecutorMetrics.scala Maven / Gradle / Ivy

There is a newer version: 3.5.1
Show 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.spark.executor

import java.util.concurrent.atomic.AtomicLongArray

import org.apache.spark.annotation.DeveloperApi
import org.apache.spark.memory.MemoryManager
import org.apache.spark.metrics.ExecutorMetricType

/**
 * :: DeveloperApi ::
 * Metrics tracked for executors and the driver.
 *
 * Executor-level metrics are sent from each executor to the driver as part of the Heartbeat.
 */
@DeveloperApi
class ExecutorMetrics private[spark] extends Serializable {
  // Metrics are indexed by ExecutorMetricType.metricToOffset
  private val metrics = new Array[Long](ExecutorMetricType.numMetrics)
  // the first element is initialized to -1, indicating that the values for the array
  // haven't been set yet.
  metrics(0) = -1

  /** Returns the value for the specified metric. */
  def getMetricValue(metricName: String): Long = {
    metrics(ExecutorMetricType.metricToOffset(metricName))
  }

  /** Returns true if the values for the metrics have been set, false otherwise. */
  def isSet(): Boolean = metrics(0) > -1

  private[spark] def this(metrics: Array[Long]) = {
    this()
    Array.copy(metrics, 0, this.metrics, 0, Math.min(metrics.size, this.metrics.size))
  }

  private[spark] def this(metrics: AtomicLongArray) = {
    this()
    ExecutorMetricType.metricToOffset.foreach { case (_, i) =>
      this.metrics(i) = metrics.get(i)
    }
  }

  /**
   * Constructor: create the ExecutorMetrics using a given map.
   *
   * @param executorMetrics map of executor metric name to value
   */
  private[spark] def this(executorMetrics: Map[String, Long]) = {
    this()
    ExecutorMetricType.metricToOffset.foreach { case (name, idx) =>
      metrics(idx) = executorMetrics.getOrElse(name, 0L)
    }
  }

  /**
   * Compare the specified executor metrics values with the current executor metric values,
   * and update the value for any metrics where the new value for the metric is larger.
   *
   * @param executorMetrics the executor metrics to compare
   * @return if there is a new peak value for any metric
   */
  private[spark] def compareAndUpdatePeakValues(executorMetrics: ExecutorMetrics): Boolean = {
    var updated = false
    (0 until ExecutorMetricType.numMetrics).foreach { idx =>
      if (executorMetrics.metrics(idx) > metrics(idx)) {
        updated = true
        metrics(idx) = executorMetrics.metrics(idx)
      }
    }
    updated
  }
}

private[spark] object ExecutorMetrics {

  /**
   * Get the current executor metrics. These are returned as an array, with the index
   * determined by ExecutorMetricType.metricToOffset.
   *
   * @param memoryManager the memory manager for execution and storage memory
   * @return the values of the metrics
   */
  def getCurrentMetrics(memoryManager: MemoryManager): Array[Long] = {
    val currentMetrics = new Array[Long](ExecutorMetricType.numMetrics)
    var offset = 0
    ExecutorMetricType.metricGetters.foreach { metricType =>
      val metricValues = metricType.getMetricValues(memoryManager)
      Array.copy(metricValues, 0, currentMetrics, offset, metricValues.length)
      offset += metricValues.length
    }
    currentMetrics
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy