使用Java自带的VisualVM监控远程服务器部署在Docker容器中的Java项目并使用Mat在线工具排查服务器内存泄露或内存溢出的原因。项目解耦,与业务模块分离单独运行定时任务
创始人
2025-01-19 12:33:10
0

事情是这样的,我们项目最近应业主的要求迁移到了新的服务器,起初一切正常,部署、上线、测试都没有问题,项目大概运行了一周的工作日时间都没出现问题,直到周六那天,项目经理打电话过来说服务器崩了,图片上传不了,验证码加载不出来等各种问题。。。然后火速连到服务器docker stats --no-stream查看了一下Docker 命令中用来显示容器资源利用情况,发现这个Java服务一直在持续的上涨到15G左右(正常也就几百兆),以至于涨到服务器挂掉了。。。额,我初步怀疑是定时任务太多的问题。

在这里插入图片描述

于是我马上咨询单位里经验比较丰富的大佬,让我去监控一下程序的进程,内存使用等情况。如果临时使用的话,就让我临时处理的话就新建一个boot项目,把定时任务都丢里面去构建一个jar,直接在服务器里java -jar跑。这个方法可能可以维持一段时间,因为本质问题还没得到解决,后面还是会出问题。于是我去上网搜了一下有个JDK文件夹里叫VisualVM的工具可以实时监控。

在这里插入图片描述

有时候程序内存溢出或者做压力测试的时候我们就需要监控我们的程序的运行状况,包括内存使用情况、CPU使用情况等等,VisualVM就是监控这些数据的一个很好的工具。

在这里插入图片描述

下面我将教大家怎么连到Docker容器中的Java服务进行实时监控

1.修改docker-compose.yml文件

在文件中添加连接端口,这里设置成1199

在这里插入图片描述

2.修改Dockerfile文件

添加配置
-Djava.rmi.server.hostname = xxx.xxx.xxx.xxx 指定宿主机的公网ip
-Dcom.sun.management.jmxremote.port = xxxx 用于Java VisualVM远程监控的端口
-Dcom.sun.management.jmxremote.rmi.port = xxxx 指定用于Java VisualVM远程监控的端口”需要挂载到宿主机的哪个端口
-Dcom.sun.management.jmxremote.authenticate = true | false 配置是否需要验证,如果true,则在使用Java VisualVM连接的时候需要你认证账号密码
-Dcom.sun.management.jmxremote.ssl = true | false 不指定ssl

ENV JAVA_OPTS="-Djava.rmi.server.hostname=192.168.1.140 -Dcom.sun.management.jmxremote.port=1199 -Dcom.sun.management.jmxremote.rmi.port=1199 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false" 

在这里插入图片描述

或者这样

在这里插入图片描述

3.开放端口1199

因每个服务器都有不同的设定,我这边是业主自行搭的服务器,通过路由控制的,需要路由那边开放1199端口。还有就是保证防火墙也给予端口开放状态,否则将无法连接!如果你是阿里云服务器,则去阿里云资源管理中的安全组进行端口的开放。

4.尝试连接Docker中的Java服务

完成下面两个步骤即可连接
在这里插入图片描述

在这里插入图片描述

5.分析Java服务的各项指标

这里是运行9分钟的时候的截图,这时CPU已经100%了,不知道是软件的问题还是什么情况。

在这里插入图片描述

这里是运行了15小时左右的截图,在这里发现了启动线程数总数2w多,以及CPU占用率100%,很大的概率存在内存泄漏

在这里插入图片描述

如VisualVM工具使用JMX连接GC出现不受此jvm支持,请看下面这篇教程如何解决
https://developer.aliyun.com/article/1402853

当然,我们也可以使用jdk自带的jconsole工具类进行分析
在这里插入图片描述

连接方式与VisualVM一样,也是IP加端口

在这里插入图片描述

6.使用mat工具分析内存溢出、内存泄露问题

软件下载安装:
自行下载安装,可以看这篇教程:https://blog.csdn.net/wts563540/article/details/132380827
mat工具下载地址:https://www.eclipse.org/mat/downloads.php

导出堆文件:

如果你的 Java 应用程序是在 Docker 容器中运行的,你可以通过以下步骤来获取容器内 Java 进程的 PID,并使用 jmap 或 jcmd 工具获取堆 dump:

获取容器内 Java 进程的 PID:首先,你需要进入正在运行 Java 应用程序的 Docker 容器中。你可以使用以下命令来执行一个临时的交互式 Shell,以便执行后续的命令:

docker exec -it  /bin/bash 

替换为你的容器 ID。

在容器内部获取 Java 进程的 PID:在容器内部执行以下命令来获取 Java 进程的 PID:

jps 

这将列出容器内运行的 Java 进程及其对应的进程 ID。

使用 jmap 或 jcmd 工具获取堆 dump:在容器内部,使用得到的 Java 进程 PID 来执行 jmap 或 jcmd命令,如前面提到的那样。确保你在容器内部已经正确设置了 JDK 的环境变量,并且具有足够的权限来执行这些命令。

使用 jmap 工具获取堆 dump:打开命令行终端,输入以下命令来获取堆 dump:

jmap -dump:format=b,file=heapdump.hprof  

替换为你要获取堆 dump 的 Java 进程的进程 ID。执行该命令后,将会生成一个名为 heapdump.bin 的堆 dump 文件。

使用 jcmd 工具获取堆 dump:打开命令行终端,输入以下命令来获取堆 dump:

jcmd  GC.heap_dump heapdump.hprof 

替换为你要获取堆 dump 的 Java 进程的进程 ID。执行该命令后,同样会生成一个名为 heapdump.bin 的堆 dump 文件。
将堆 dump 文件从容器中复制到宿主机:获取到堆 dump 文件后,你可能希望将文件从容器中复制到宿主机上进行分析。你可以使用 docker cp 命令来实现这一点,例如:

docker cp :/path/to/heapdump.hprof /path/on/host/heapdump.hprof 

其中 /path/to/heapdump.hprof 是容器内的堆 dump 文件路径,/path/on/host/heapdump.hprof 是宿主机上的目标路径。

接着我们使用mat工具打开:有可能会打不开。。。我暂时没找到解决办法。。。

在这里插入图片描述

别急,还有在线版的工具来分析内存溢出、内存泄露。在线地址:https://heaphero.io/heap-index.jsp

在这里插入图片描述

这个在线版也可以进行分析,但是并没有mat工具那么详细!
我使用这个在线版分析了我导出的堆文件,导入后可以看到分析出来的结果报告,下面有更详细的信息我就不展示了。

在这里插入图片描述

额。。。意思是这个对象被持续加载了11w个

在这里插入图片描述

我还在郁闷到底是谁写的那么史的代码,当我打开代码看了一下发现小丑竟然是自己。。。。。。。🤡

在这里插入图片描述

算了,慢慢一个一个找代码看看哪里有问题吧…😅

补充(排除代码问题):

初步排查,有可能是多个定时任务的问题,抢占资源。项目中定时任务好多,大概十几个,我们可以单独创建一个新项目,把这些定时任务放到新项目里,单独运行。这样我们可以与业务模块隔离开,不会影响到主业务。这样既降低了耦合度,也易于管理和监控。

相关内容

热门资讯

透视新版!WePOker有没有... 透视新版!WePOker有没有透视方法,佛手在线是不是有挂,学习教程(有挂详细)-哔哩哔哩1)WeP...
透视免费!拱趴大菠萝有挂吗(透... 透视免费!拱趴大菠萝有挂吗(透视)一贯真的是有挂,必赢教程(有挂代打)-哔哩哔哩1、金币登录送、破产...
第三分钟必备!aapoker安... 第三分钟必备!aapoker安装包怎么使用(透视)好像真的有挂,解密教程(有挂神器)-哔哩哔哩1、点...
透视总结!hhpoker为什么... 透视总结!hhpoker为什么一直输,newpoker怎么安装脚本,办法教程(有挂辅助)-哔哩哔哩1...
透视规律!wepoker正确养... 透视规律!wepoker正确养号方法(透视)原来是真的挂,爆料教程(有挂辅助器)-哔哩哔哩1、wep...
三分钟总结!德扑之心免费透视(... 三分钟总结!德扑之心免费透视(透视)一直是真的挂,德州论坛(有挂存在)-哔哩哔哩1、任何德扑之心免费...
透视新版!wepoker免费透... 透视新版!wepoker免费透视脚本,wejoker辅助机器人,课程教程(有挂教程)-哔哩哔哩1)w...
透视攻略!aa poker辅助... 透视攻略!aa poker辅助(透视)好像是真的挂,黑科技教程(有挂安卓版本)-哔哩哔哩aa pok...
5分钟总结!德州私人局怎么透视... 5分钟总结!德州私人局怎么透视(透视)真是存在有挂,透牌教程(有挂细节)-哔哩哔哩所有人都在同一条线...
透视辅助!wpk私人局有透视吗... 透视辅助!wpk私人局有透视吗,智星菠萝可以辅助吗,办法教程(新版有挂)-哔哩哔哩1、用户打开应用后...