Haibo Suen created FLINK-11379:
----------------------------------

             Summary: "java.lang.OutOfMemoryError: Direct buffer memory" when 
TM loads a large size TDD
                 Key: FLINK-11379
                 URL: https://issues.apache.org/jira/browse/FLINK-11379
             Project: Flink
          Issue Type: Bug
          Components: TaskManager
    Affects Versions: 1.7.1, 1.7.0
            Reporter: Haibo Suen
            Assignee: Haibo Suen


When TM loads a offloaded TDD with large size, it may throw a 
"java.lang.OutOfMemoryError: Direct Buffer Memory" error. The loading uses 
nio's _Files.readAllBytes()_ to read serialized TDD. In the call stack of 
_Files.readAllBytes()_ , it will allocate a direct memory buffer which's size 
is equal the length of the file. This will cause OutOfMemoryErro error when 
direct memory is not enough.

A fixed size direct buffer should be used to read a file to avoid 
OutOfMemoryErro error, such as a 8K buffer.

The exception stack is as follows (this exception stack is from an old Flink 
version, but the master branch has the same problem).



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

Reply via email to