-
Notifications
You must be signed in to change notification settings - Fork 28.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[SPARK-21099][Spark Core] INFO Log Message Using Incorrect Executor I… #18308
Conversation
…dle Timeout Value
LGTM. BTW can you please complement the PR description, thanks. |
Jenkins test this please |
Test build #78086 has finished for PR 18308 at commit
|
@@ -432,8 +432,10 @@ private[spark] class ExecutorAllocationManager( | |||
if (testing || executorsRemoved.nonEmpty) { | |||
executorsRemoved.foreach { removedExecutorId => | |||
newExecutorTotal -= 1 | |||
val hasCachedBlocks = SparkEnv.get.blockManager.master.hasCachedBlocks(executorId); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This variable executorId
is not defined, should change to removedExecutorId
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
And final semicolon ";" is not necessary.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Btw, there could be a chance when querying executor from BlockManager, the executor/block manager was already removed, so we will potentially get false
.
@jerryshao - I pushed another commit fixing removedExecutorId and removing ';'...thx for feedback on that. Regarding the edge case where the block manager was already removed and could potentially get |
ok to test |
Test build #78126 has finished for PR 18308 at commit
|
Yes, that's the case, we cannot differentiate this two scenarios. But I think it is fine, since it is just a log issue and hard for us to differentiate them in the current code. |
Test build #3799 has finished for PR 18308 at commit
|
@@ -432,8 +432,10 @@ private[spark] class ExecutorAllocationManager( | |||
if (testing || executorsRemoved.nonEmpty) { | |||
executorsRemoved.foreach { removedExecutorId => | |||
newExecutorTotal -= 1 | |||
val hasCachedBlocks = SparkEnv.get.blockManager.master.hasCachedBlocks(removedExecutorId) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is a pretty expensive call just so you can print a more accurate log message... at the very least it should be inside the logInfo
call:
logInfo {
expensiveStuff()
"This is the log message referencing the expensive stuff."
}
But I'd prefer a solution that doesn't make this call at all, since INFO is more often than not enabled.
Can one of the admins verify this patch? |
Ping @ihazem |
Ping @ihazem to update or close |
logInfo(s"Removing executor $removedExecutorId because it has been idle for " + | ||
s"$executorIdleTimeoutS seconds (new desired total will be $newExecutorTotal)") | ||
s"${if (SparkEnv.get.blockManager.master.hasCachedBlocks(executorId)) cachedExecutorIdleTimeoutS else executorIdleTimeoutS} seconds (new desired total will be $newExecutorTotal)") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is hard to read. @vanzin 's idea is better. Can you split this into two statements? cheap one at info, expensive one at debug?
Can you update the title to:
? |
Is this the final modified code @ihazem , why do you have Can you please at least do a round of self-review before pushing the changes. |
@jerryshao - sorry about that...let me remove the logic outside the logInfo statements. Missed that. I'll do some more self-review and peer-review going fwd before submitting to not waste everyone's time here. @jiangxb1987 - i'll update title per your recommendation @srowen - do you or @vanzin have any recommendations on making a cheaper call in the info level? I can definitely make the more expensive call at debug/warn, but could use some direction on a cheaper call for the info level. Basically, we want to use the cachedExecutorIdleTimeoutS if the executor has cached blocks (whereas right now it uses executorIdleTimeoutS). Thx! |
There is no cheaper call you can make. Which is the problem here. So either you have to modify the code so that it keeps track of why the executor has timed out (i.e. more state being passed around), or you need to tweak the message so that it says that the timeout is different when there are cached blocks on the executor. I'm not so sure there's a lot to gain from printing the exact timeout value in this message, so I'm leaning towards just tweaking the message a little bit (e.g. add "or $otherTimeout ms if executor had cached blocks"), or even not doing anything. |
…dle Timeout Value
What changes were proposed in this pull request?
Updated the INFO logging method (logInfo) to use $timeout instead, which uses cachedExecutorIdleTimeoutS if the executor has cached blocks
How was this patch tested?
Testing was done by doing the following:
executorIdleTimeout=30
cachedExecutorIdleTimeout=20
shell.log.level=INFO
scala> val textFile = sc.textFile("/user/spark/applicationHistory/app_1234")
scala> textFile.cache().count()
Please review http://spark.apache.org/contributing.html before opening a pull request.