[ https://issues.apache.org/jira/browse/KAFKA-4293?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15999626#comment-15999626 ]
ASF GitHub Bot commented on KAFKA-4293: --------------------------------------- Github user radai-rosenblatt closed the pull request at: https://github.com/apache/kafka/pull/2025 > ByteBufferMessageSet.deepIterator burns CPU catching EOFExceptions > ------------------------------------------------------------------ > > Key: KAFKA-4293 > URL: https://issues.apache.org/jira/browse/KAFKA-4293 > Project: Kafka > Issue Type: Bug > Components: core > Affects Versions: 0.10.0.1 > Reporter: radai rosenblatt > Assignee: radai rosenblatt > > around line 110: > {noformat} > try { > while (true) > innerMessageAndOffsets.add(readMessageFromStream(compressed)) > } catch { > case eofe: EOFException => > // we don't do anything at all here, because the finally > // will close the compressed input stream, and we simply > // want to return the innerMessageAndOffsets > {noformat} > the only indication the code has that the end of the oteration was reached is > by catching EOFException (which will be thrown inside > readMessageFromStream()). > profiling runs performed at linkedIn show 10% of the total broker CPU time > taken up by Throwable.fillInStack() because of this behaviour. > unfortunately InputStream.available() cannot be relied upon (concrete example > - GZipInputStream will not correctly return 0) so the fix would probably be a > wire format change to also encode the number of messages. -- This message was sent by Atlassian JIRA (v6.3.15#6346)