一次 java heap space 解决过程

    负责一个javaweb项目,周四上午正在紧张的工作(划水),客户突然在群里喊了句正式服管理员账号登不上了。

    赶紧打开网页>开启调试模式>登录,发现一个接口一直等待响应。postman掉一下,响应为空!喵喵喵,测试服试一下,接口报错 java heap space ???关于java heap space 原因请看这篇文章java 内存溢出 栈溢出的原因与排查方法

    测试服和正式服同时出现问题,有人部署项目了?登录服务器,部署时间是上个月,帅锅计划失败。什么问题呢?稳定跑了一个月,代码出问题的可能性不大,数据库?    连上数据库>打开表,30w+??? 测试服务器9w+  喵喵喵,我们的业务需求是不可能让这个表有这么多数据的,所以表的数据异常了!而我们测试服务器由于内存比较小,所以在select * 的时候直接堆溢出,报了 java heap space 异常,而正式服的虚拟机内存设置的比较高,所以不会溢出,但是由于表没有建索引(设计时考虑到数据不会太多,不建索引是正确的)查的慢,所以接口一直等待响应。

    关于java head space 的解决方案也很简单,这里给大家贴一下

    跟据网上的答案大致有这两种解决方法:
    1、设置环境变量
    set JAVA_OPTS= -Xms32m -Xmx512m
    可以根据自己机器的内存进行更改,但本人测试这种方法并没有解决问题。可能是还有哪里需要设置。

    2、java -Xms32m -Xmx800m className
    就是在执行JAVA类文件时加上这个参数,其中className是需要执行的确类名。(包括包名)
    这个解决问题了。而且执行的速度比没有设置的时候快很多。

    但是这写方法并不适用我们遇到的问题,我们要解决的是数据重复的问题。

    问题算是定位到了,但是数据为啥异常啊???好像有重复数据,SELECT count(id) from a group by id having count(id)>1查一下,每条数据都重复了两千七百多次???哪来的这么多重复数据,主键也是重复的。最后发现是一个同事(实习生何苦为难实习生)写同步任务时复制了一行代码,把这个表也进行同步了。

    接着就是解决问题了,删除多余同步代码,删除重复数据。然后就跳进了下一个坑mysql删除完全重复的数据(主键重复)


   

你可能感兴趣的:(一次 java heap space 解决过程)