You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@flink.apache.org by "ASF GitHub Bot (Jira)" <ji...@apache.org> on 2022/06/16 10:51:00 UTC

[jira] [Updated] (FLINK-28065) A never reached code in ProcessMemoryUtils Class

     [ https://issues.apache.org/jira/browse/FLINK-28065?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

ASF GitHub Bot updated FLINK-28065:
-----------------------------------
    Labels: pull-request-available  (was: )

> A never reached code in ProcessMemoryUtils Class
> ------------------------------------------------
>
>                 Key: FLINK-28065
>                 URL: https://issues.apache.org/jira/browse/FLINK-28065
>             Project: Flink
>          Issue Type: Bug
>          Components: Runtime / Configuration
>    Affects Versions: 1.16.0
>            Reporter: zhuyufeng
>            Assignee: zhuyufeng
>            Priority: Minor
>              Labels: pull-request-available
>
> The main logic of *sanityCheckTotalProcessMemory* method in ProcessMemoryUtils Class will {color:#FF0000}never be executed{color}.
>  
> this is reason:
> In *deriveJvmMetaspaceAndOverheadFromTotalFlinkMemory* method of ProcessMemoryUtils Class, the [logic|https://github.com/apache/flink/blob/master/flink-runtime/src/main/java/org/apache/flink/runtime/util/config/memory/ProcessMemoryUtils.java#L170] determines whether TotalProcessMemory is explicitly configured.
> In "false" branch(means TotalProcessMemory is not explicitly configured), the [logic|https://github.com/apache/flink/blob/master/flink-runtime/src/main/java/org/apache/flink/runtime/util/config/memory/ProcessMemoryUtils.java#L184] calls the *sanityCheckTotalProcessMemory* method.
> However, the main logic of *sanityCheckTotalProcessMemory* method only executed [when TotalProcessMemory is explicitly configured|https://github.com/apache/flink/blob/master/flink-runtime/src/main/java/org/apache/flink/runtime/util/config/memory/ProcessMemoryUtils.java#L247], so the main logic probably never be executed.
>  
> Compare with [call location|https://github.com/apache/flink/blob/master/flink-runtime/src/main/java/org/apache/flink/runtime/util/config/memory/taskmanager/TaskExecutorFlinkMemoryUtils.java#L101] of *sanityCheckTotalFlinkMemory* method(this method is similar to the logic of the *sanityCheckTotalProcessMemory* method in that it compares whether the derived memory size is consistent with the explicitly configured memory size) in TaskExecutorFlinkMemoryUtils Class, i guess *sanityCheckTotalProcessMemory* method should be called behind "if" branch, not in the "if" branch.



--
This message was sent by Atlassian Jira
(v8.20.7#820007)