http 502错误(多层循环引起的性能问题)

作者:黄小亮

 

现象描述:

页面查询速度非常慢, 直到报出502 错误(Bad gateway)

 

现象描述:

页面查询速度非常慢, 直到报出502 错误(Bad gateway)

错误分析

分析过程:

在项目做了压力测试后( 压力测试和功能是用的是一个数据库, 压力测试时产生了大量数据 ), 测试环境的查询变的很慢, 超过了mod_jk.conf 中配置的请求超时时间(JkWorkerProperty worker.localnode.socket_timeout=20, 请求转发给jboss 后,最长等待的时间 ). 页面报出了502 错误.

 

 

原因分析:

通过debug 观察到一次查询查出来的 parentNodeDOList childNodeDOList 各有近万条数据, 下面嵌套进行数据的组装, 消耗了比较多的时间. 代码片段如下:

( for ParentNod eDO parentNodeDO: parentNodeDOList ()) {

                    parentNodeDOId = parentNodeDO.getId();

                    for (ChildNodeDO childNodeDO : childNodeDOList ) {

                       if (childNodeDO.getParentNodeId().equals(parentNodeDOId)) {

                          parentNodeDO.getChildNodeDOList().add(childNodeDO);

                        }

                    }

}

 

正确用法

正确用法 ( 将上面代码中 parentNodeDOList 转换为 Map, 再进行组装 , 将 N ²降为 N) :

for (ChildNodeDO childNodeDO : childNodeDOList) {

ParentNod eDO    parentNod eDO

parentNod eMap .get(childNodeDO.getParentNodeDOId());

                parentNodeDO.getChildNodeDOList().add(childNodeDO);

        }

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值