[ 
https://issues.apache.org/jira/browse/FLINK-23357?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17379134#comment-17379134
 ] 

Borland Won edited comment on FLINK-23357 at 7/12/21, 11:23 AM:
----------------------------------------------------------------

add pic


was (Author: borland):
[~chesnay] Thanks for your reply. I find one of the classloaders .

this is result for "merge the shortest paths to GC roots"

!image-2021-07-12-19-20-13-742.png!

 

and  this is result for "path to GC roots"

!image-2021-07-12-19-18-32-168.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)

Reply via email to