List<Vo>与服务器挂掉问题

上周末系统变更上线,大约发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很可能会丢失必要的查询条件,而导致全量查询。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值