公众号重复推送消息的Bug

正常逻辑:在关注公众号后,用关注时间+延后时间来进行定时任务执行推送,在特定的时间段推送特定的消息给微信用户,每个access token的用户同一条消息只会接收到一次。

Bug表象:有一部分微信用户接到了重复的消息推送,比如关注后2小时的推送任务是“你好”,连续收到多条“你好”。造成了极大的用户不良体验,但是QA同学和自测试环境怎么都无法复现这个Bug,无从下手排查。

使用技术:Node.js的egg.js框架 + Linux的CronTab定时器任务 + Mysql数据库 + 微信公众号开发工具
排查原因:

在执行发送任务时将文案等数据拼装好交由微信那边的接口发送到用户的微信,再获取哪些定时任务需要执行时候,是30秒轮询一次看执行时间execute_time是否到了,到了的话就拿出来放入队列中等待执行,执行完毕再修改数据库定时任务状态为已执行。
(1)由于node是单线程,在用户量到三四万这个瓶颈的时候,就会容易出现这个Bug,因为它单线程执行,30秒要推那么多条消息显然是不可能的,于是30秒还没推送完全部,下一次30秒轮询又到了,又把没执行的定时任务拿出来转圈圈等待发送,于是同一个用户的同一个定时任务推送越堆积越多,导致最后推送N条重复的。
(2)我们进行的不是简单的推送,还要查订单,查课程信息,查老师联系方式,查优化方案,查上课时间

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值