一次线上内存溢出的事故

内存溢出

突然在昨天下午,项目的服务突然抛出来异常信息如下:

{“code”:"-1",“msg”:“系统错误:Cannot deserialize; nested exception is org.springframework.core.serializer.support.SerializationFailedException: Failed to deserialize payload. Is the byte array a result of corresponding serialization for DefaultDeserializer?; nested exception is java.lang.OutOfMemoryError: Java heap space”}

首先,你要对jvm有一定的了解,才能排查出来问题的所在

常用的命令
top: 查看磁盘的信息
free:查看内存的情况
jps: 具体 [options]选项解析:
-q:仅输出VM标识符,不包括classname,jar name,arguments in main method;
-m:输出main method的参数;
-l:输出完全的包名,应用主类名,jar的完全路径名;
-v:输出jvm参数 ;
-V:输出通过flag文件传递到JVM中的参数(.hotspotrc文件或-XX:Flags=所指定的文件 ;

jinfo -flags 21215----------------------查看jvm的配置-虚拟机的配置信息-21215是端口号
jstat -gc 21215 2000 10000----------------------监控端口号的jvm的情况–21215是端口号

基本的排查思路

先输入jps,再输入top
在这里插入图片描述
在这里插入图片描述

1: 通过上面的命令,查看cpu和内存,消耗比较高的进程的端口号
2:通过命令:可以看出端口号21215端口的内存的消耗率比较高
3:找到21215进程所在的服务下面,如果是java服务,到项目的部署目录下,
4:查看tomcat目录下的jvm的信息, 你可以看到catalina.sh文件。
5:由此可见,新生代的空间分配比较小,老年代的内存空间占用率比较高
6: 解决方案:把新生代的空间设置的更大一点。避免内存使用的时候,空间不足,导致报错,内存不足。

linux下tomcat设置jvm的参数

tomcat启动执行的是
tomcat/bin/startup.sh,
startup.sh执行的是catalina.sh
所以要在catalina.sh中进行设置
在Tomcat服务器上设置JVM参数

  set CATALINA_OPTS=-Xmx5
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值