[
https://issues.apache.org/jira/browse/FLINK-23357?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Borland Won updated FLINK-23357:
--------------------------------
Attachment: image-2021-07-12-19-20-13-742.png
> jobmanager metaspace oom
> ------------------------
>
> Key: FLINK-23357
> URL: https://issues.apache.org/jira/browse/FLINK-23357
> Project: Flink
> Issue Type: Bug
> Affects Versions: 1.12.2
> Reporter: Borland Won
> Priority: Major
> Attachments: image-2021-07-12-16-57-55-256.png,
> image-2021-07-12-17-06-17-218.png, image-2021-07-12-19-20-13-742.png
>
>
> *Flink Version: 1.12.2*
> Hi . I created a standalone HA cluster(with 3 taskmanager and 2 jobmanager),
> and repeatedly submit new jobs to the cluster and cancel old jobs via rest
> api . Then jobmanager master got the increasing metaspace.
> !image-2021-07-12-16-57-55-256.png!
> Soon it will OOM and get the exception below:
> 2021-06-21 15:44:06,637 ERROR
> org.apache.flink.runtime.webmonitor.handlers.JarRunHandler [] - Unhandled
> exception.2021-06-21 15:44:06,637 ERROR
> org.apache.flink.runtime.webmonitor.handlers.JarRunHandler [] - Unhandled
> exception.java.util.concurrent.CompletionException:
> org.apache.flink.client.program.ProgramInvocationException: The program's
> entry point class 'xxx.xxx.xxx.XXXBootstrap' caused an exception during
> initialization: Metaspace. The metaspace out-of-memory error has occurred.
> This can mean two things: either Flink Master requires a larger size of JVM
> metaspace to load classes or there is a class loading leak. In the first case
> 'jobmanager.memory.jvm-metaspace.size' configuration option should be
> increased. If the error persists (usually in cluster after several job
> (re-)submissions) then there is probably a class loading leak in user code or
> some of its dependencies which has to be investigated and fixed. The Flink
> Master has to be shutdown... at
> org.apache.flink.runtime.webmonitor.handlers.utils.JarHandlerUtils$JarHandlerContext.toPackagedProgram(JarHandlerUtils.java:184)
> ~[flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.runtime.webmonitor.handlers.utils.JarHandlerUtils$JarHandlerContext.applyToConfiguration(JarHandlerUtils.java:141)
> ~[flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.runtime.webmonitor.handlers.JarRunHandler.handleRequest(JarRunHandler.java:95)
> ~[flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.runtime.webmonitor.handlers.JarRunHandler.handleRequest(JarRunHandler.java:53)
> ~[flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.runtime.rest.handler.AbstractRestHandler.respondToRequest(AbstractRestHandler.java:83)
> ~[flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.runtime.rest.handler.AbstractHandler.respondAsLeader(AbstractHandler.java:195)
> ~[flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.runtime.rest.handler.LeaderRetrievalHandler.lambda$channelRead0$0(LeaderRetrievalHandler.java:83)
> ~[flink-dist_2.11-1.12.2.jar:1.12.2] at
> java.util.Optional.ifPresent(Optional.java:159) [?:1.8.0_292] at
> org.apache.flink.util.OptionalConsumer.ifPresent(OptionalConsumer.java:45)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.runtime.rest.handler.LeaderRetrievalHandler.channelRead0(LeaderRetrievalHandler.java:80)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.runtime.rest.handler.LeaderRetrievalHandler.channelRead0(LeaderRetrievalHandler.java:49)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.SimpleChannelInboundHandler.channelRead(SimpleChannelInboundHandler.java:99)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:379)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:365)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:357)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.runtime.rest.handler.router.RouterHandler.routed(RouterHandler.java:115)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.runtime.rest.handler.router.RouterHandler.channelRead0(RouterHandler.java:94)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.runtime.rest.handler.router.RouterHandler.channelRead0(RouterHandler.java:55)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.SimpleChannelInboundHandler.channelRead(SimpleChannelInboundHandler.java:99)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:379)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:365)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:357)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.handler.codec.MessageToMessageDecoder.channelRead(MessageToMessageDecoder.java:103)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:379)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:365)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:357)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.runtime.rest.FileUploadHandler.channelRead0(FileUploadHandler.java:208)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.runtime.rest.FileUploadHandler.channelRead0(FileUploadHandler.java:69)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.SimpleChannelInboundHandler.channelRead(SimpleChannelInboundHandler.java:99)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:379)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:365)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:357)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.CombinedChannelDuplexHandler$DelegatingChannelHandlerContext.fireChannelRead(CombinedChannelDuplexHandler.java:436)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.handler.codec.ByteToMessageDecoder.fireChannelRead(ByteToMessageDecoder.java:324)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.handler.codec.ByteToMessageDecoder.channelRead(ByteToMessageDecoder.java:296)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.CombinedChannelDuplexHandler.channelRead(CombinedChannelDuplexHandler.java:251)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:379)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:365)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:357)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.DefaultChannelPipeline$HeadContext.channelRead(DefaultChannelPipeline.java:1410)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:379)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:365)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.DefaultChannelPipeline.fireChannelRead(DefaultChannelPipeline.java:919)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.nio.AbstractNioByteChannel$NioByteUnsafe.read(AbstractNioByteChannel.java:163)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:714)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.nio.NioEventLoop.processSelectedKeysOptimized(NioEventLoop.java:650)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.nio.NioEventLoop.processSelectedKeys(NioEventLoop.java:576)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:493)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.util.concurrent.SingleThreadEventExecutor$4.run(SingleThreadEventExecutor.java:989)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.shaded.netty4.io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74)
> [flink-dist_2.11-1.12.2.jar:1.12.2] at java.lang.Thread.run(Thread.java:748)
> [?:1.8.0_292]Caused by:
> org.apache.flink.client.program.ProgramInvocationException: The program's
> entry point class 'xxx.xxx.xxx.XXXBootstrap' caused an exception during
> initialization: Metaspace. The metaspace out-of-memory error has occurred.
> This can mean two things: either Flink Master requires a larger size of JVM
> metaspace to load classes or there is a class loading leak. In the first case
> 'jobmanager.memory.jvm-metaspace.size' configuration option should be
> increased. If the error persists (usually in cluster after several job
> (re-)submissions) then there is probably a class loading leak in user code or
> some of its dependencies which has to be investigated and fixed. The Flink
> Master has to be shutdown... at
> org.apache.flink.client.program.PackagedProgram.loadMainClass(PackagedProgram.java:497)
> ~[flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.client.program.PackagedProgram.<init>(PackagedProgram.java:152)
> ~[flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.client.program.PackagedProgram.<init>(PackagedProgram.java:64)
> ~[flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.client.program.PackagedProgram$Builder.build(PackagedProgram.java:685)
> ~[flink-dist_2.11-1.12.2.jar:1.12.2] at
> org.apache.flink.runtime.webmonitor.handlers.utils.JarHandlerUtils$JarHandlerContext.toPackagedProgram(JarHandlerUtils.java:182)
> ~[flink-dist_2.11-1.12.2.jar:1.12.2] ... 50 moreCaused by:
> java.lang.OutOfMemoryError: Metaspace. The metaspace out-of-memory error has
> occurred. This can mean two things: either Flink Master requires a larger
> size of JVM metaspace to load classes or there is a class loading leak. In
> the first case 'jobmanager.memory.jvm-metaspace.size' configuration option
> should be increased. If the error persists (usually in cluster after several
> job (re-)submissions) then there is probably a class loading leak in user
> code or some of its dependencies which has to be investigated and fixed. The
> Flink Master has to be shutdown...
>
>
>
> I know " there is probably a class loading leak in user code or some of its
> dependencies which has to be investigated and fixed" , but don't know how to
> recognize it.
> I jmap the jobmanager process which is coming to OOM . Bootstrap is my
> entrance class with main method. Why it and the other function class were
> loaded 103 times ?
> !image-2021-07-12-17-06-17-218.png!
--
This message was sent by Atlassian Jira
(v8.3.4#803005)