接口时延超高,记录自己的一次性能调优

本文记录了一次性能调优的过程,针对接口时延问题,通过缩短定时任务间隔、优化数据处理方式、调整ES查询策略、代码内部优化、线程池批处理等措施,成功将1000条数据处理时间从194秒降低到11秒,性能提升了19倍。文中还探讨了可能的进一步优化方案。
摘要由CSDN通过智能技术生成

初始状态:

arthas查看任务时间: 1000条数据处理了194秒,性能较差,吞吐量在 5条/s,尴尬,194秒!!!

arthas命令:trace -E cn.migu.deal.pori.....SubscribeFlowRecordTask auditSubFlowRecord 

 

优化点1:

 定时任务间隔原先配置为 

@Scheduled(initialDelay = 30000,fixedDelayString ="60000")

将fixedDelayString 时间优化为 1000 由 60秒间隔,缩短为1秒间隔,提高定时任务执行频率

优化点2:

  任务前期,防止出现数据被重复稽核的情况,主线程设置为同步处理,处理速度较慢,优化为异步

  考虑点: 1、避免重复消费问题 提出方案:

                       方案一:按照时间排序,记录上次任务执行时间,下一次查询时,时间大于等于上次查询时间

                                     同时设置缓存,缓存上次消费的所有的记录id&#x

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值