2020-08-27问题记录

问题描述

本地测试开发验证没有问题,一切正常,部署测试环境后虽然有零散小问题,但最终还是通过了测试,一切数据库脚本还有配置准备就绪后,发布灰度环境,结果发现接口调用时间很长,大约5s左右,但是测试环境没有超过500ms。

问题分析

因为测试环境和灰度环境代码完全一致,并没有怀疑是代码的问题,其次看数据库脚本(测试环境是直接使用工具创建,生产环境需要用脚本创建数据库和索引以及数据初始化),验证索引还有数据情况,使用工具查询也是正常,故而暂时认为数据库也是正常的。再分析程序日志,发现测试环境基本上一条sql只需要1ms就可以返回结果,而灰度上则大约20ms,数据库查询大约将近200次,所以测试环境200ms左右,而生产上需要4000ms多。

问题定位

因为程序中在for循环中使用了数据库查询(虽然知道这种方式不可取,但是业务场景需要,暂时这么实现,而且测试环境没问题,就没有优化),所以猜测可能是频繁和数据库连接,造成的数据查询时间较长。

优化方案

采用空间换时间的方式,多使用一些中间集合,将程序优化,不在for循环中去做数据库操作,尝试下是否会提升效率。

结果

测试环境500ms优化到50ms左右
灰度环境由原来的8s左右优化至700-800ms,耗时主要用在对象转换和字符串筛选。

结论

最好不要在循环中写数据库相关操作。。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值