ExecutorAllocationClient
is a contract for clients to communicate with a cluster manager to request or kill executors.
getExecutorIds(): Seq[String]
getExecutorIds
is a private[spark]
method to calculate the identifiers of the executors in use.
Note
|
It is used when SparkContext calculates the executors in use and also when Spark Streaming manages executors.
|
requestTotalExecutors(
numExecutors: Int,
localityAwareTasks: Int,
hostToLocalTaskCount: Map[String, Int]): Boolean
requestTotalExecutors
is a private[spark]
method to update the cluster manager with the exact number of executors desired. It returns whether the request has been acknowledged by the cluster manager (true
) or not (false
).
Note
|
It is used when:
|
requestExecutors(numAdditionalExecutors: Int): Boolean
requestExecutors
requests additional executors from a cluster manager and returns whether the request has been acknowledged by the cluster manager (true
) or not (false
).
Note
|
It is used when SparkContext requests additional executors (for coarse-grained scheduler backends only).
|
killExecutor(executorId: String): Boolean
killExecutor
requests that a cluster manager to kill a single executor that is no longer in use and returns whether the request has been acknowledged by the cluster manager (true
) or not (false
).
Note
|
The default implementation simply calls killExecutors (with a single-element collection of executors to kill). |
Note
|
It is used in:
|
killExecutors(executorIds: Seq[String]): Boolean
killExecutors
requests that a cluster manager to kill one or many executors that are no longer in use and returns whether the request has been acknowledged by the cluster manager (true
) or not (false
).
Note
|
Interestingly, it is only used for killExecutor. |