You are viewing a plain text version of this content. The canonical link for it is here.
Posted to jira@kafka.apache.org by "diehu (Jira)" <ji...@apache.org> on 2021/03/19 01:42:00 UTC

[jira] [Created] (KAFKA-12507) java.lang.OutOfMemoryError: Direct buffer memory

diehu created KAFKA-12507:
-----------------------------

             Summary: java.lang.OutOfMemoryError: Direct buffer memory
                 Key: KAFKA-12507
                 URL: https://issues.apache.org/jira/browse/KAFKA-12507
             Project: Kafka
          Issue Type: Bug
          Components: core
         Environment: kafka version: 2.0.1
java version: 
java version "1.8.0_211"
Java(TM) SE Runtime Environment (build 1.8.0_211-b12)
Java HotSpot(TM) 64-Bit Server VM (build 25.211-b12, mixed mode)

the command we use to start kafka broker:
java -Xmx1G -Xms1G -server -XX:+UseG1GC -XX:MaxGCPauseMillis=20 -XX:InitiatingHeapOccupancyPercent=35 -Djava.awt.headless=true -XX:+ExplicitGCInvokesConcurrent 
            Reporter: diehu


Hi, we have three brokers in our kafka cluster, and we use scripts to send data to kafka at a rate of about 3.6w eps. After about one month, we got the OOM error: 
{code:java}
[2021-01-09 17:12:24,750] ERROR Processor got uncaught exception. (kafka.network.Processor)
java.lang.OutOfMemoryError: Direct buffer memory
    at java.nio.Bits.reserveMemory(Bits.java:694)
    at java.nio.DirectByteBuffer.<init>(DirectByteBuffer.java:123)
    at java.nio.ByteBuffer.allocateDirect(ByteBuffer.java:311)
    at sun.nio.ch.Util.getTemporaryDirectBuffer(Util.java:241)
    at sun.nio.ch.IOUtil.read(IOUtil.java:195)
    at sun.nio.ch.SocketChannelImpl.read(SocketChannelImpl.java:380)
    at org.apache.kafka.common.network.PlaintextTransportLayer.read(PlaintextTransportLayer.java:104)
    at org.apache.kafka.common.network.NetworkReceive.readFrom(NetworkReceive.java:117)
    at org.apache.kafka.common.network.KafkaChannel.receive(KafkaChannel.java:335)
    at org.apache.kafka.common.network.KafkaChannel.read(KafkaChannel.java:296)
    at org.apache.kafka.common.network.Selector.attemptRead(Selector.java:562)
    at org.apache.kafka.common.network.Selector.pollSelectionKeys(Selector.java:498)
    at org.apache.kafka.common.network.Selector.poll(Selector.java:427)
    at kafka.network.Processor.poll(SocketServer.scala:679)
    at kafka.network.Processor.run(SocketServer.scala:584)
    at java.lang.Thread.run(Thread.java:748){code}
 the kafka server is not shutdown, but always get this error. And at the same time, data can not be produced to kafka cluster, consumer can not consume data from kafka cluster.

We used the recommended java parameter XX:+ExplicitGCInvokesConcurrent  but it seems not useful. 

 Only kafka cluster restart helps to fix this problem.

 



--
This message was sent by Atlassian Jira
(v8.3.4#803005)