上周末系统变更上线,大约发40多个包,其中有一个包,被eops系统依赖,用户使用过程中发现经常页面丢失脚本。
根据服务查询到对应的tomcat应用,发现应用挂掉,kafka链接关闭。
JVM退出,进程KILL掉了,查询日志发现,内存溢出。
我们大多手工处理OS,但是并不是专业JVM管理员,大多考虑问题是从业务考虑,需求变动考虑。
这包增加了一些接口,其中有一个接口调用一分钟后服务器旧挂掉了,检查下sql发现问题。
……
String a = json.getString("a");
String b =json.getString("b");
VO vo = new VO();
vo.setA(a);
vo.setB(b);
List<VO> voList = dao.findList(vo);
……
mybatis查询
select ……
from p_task t
where t.delete_flag =1
<if test="a!=nul ">
and
</if>
伪代码如上,有一个接口根据参数去查询任务细节,然后进行业务逻辑处理。
问题来了,我们在使用mybatis的时候,很多时候不考虑数据结构的内存情况,往往使用通用sql和返回值。
这个问题的核心是,json没有接受到对应的可用数据,查询条件是空,传入到mybatis后,做了全量查询。
然后list就爆掉了。
警戒:
1、 java对象在使用的时候一定要注意IO和内存消耗问题。
2、空判断一定是核心,除了规避空指针,还要考虑mybatis查询的影响。返回数据内存占用情况一定考虑,并不是所有查询都是按照理论值来的,vo很可能会丢失必要的查询条件,而导致全量查询。