问答

rabbitmq 延时消息 计时不准确 是什么原因?

作者:admin 2021-05-14 我要评论

这是go 写的一个延时处理的考试收卷延时消息 rabbitmq已安装了延时消息插件 examRecord.MyExamination.AnswerTime = 120 分钟 `delayInt := function.GenerateRa...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

这是go 写的一个延时处理的考试收卷延时消息
rabbitmq已安装了延时消息插件
examRecord.MyExamination.AnswerTime = 120 分钟

`delayInt := function.GenerateRangeNum(10, 100) //这是一个随机数 71
ExpireTime := strconv.FormatInt(examRecord.MyExamination.AnswerTime601000+int64(delayInt)*1000, 10)
logger.Log(logger.InfoLevel,delayInt)// 值为71
logger.Log(logger.InfoLevel,ExpireTime)// 值为 7271000
body, _ := proto.Marshal(resp.ExamRecord)
if err := h.Broker.Publish(AutomaticHandingInTopic, &broker.Message{
// "delay": ExpireTime 兼容阿里云AMQP
Header: map[string]string{"x-delay": ExpireTime, "delay": ExpireTime},
Body: body,
}, rabbitmq.DeliveryMode(2)); err != nil {
resp.Error = &pb.Error{Description: err.Error()}
}`

以上代码执行后 rabbitmq 会提前几十秒钟执行了,正常应该是7271秒后才执行呀,是因为rabbitmq计时不准确吗?还是什么原因,感觉时间越长,误差就越大,几分钟的时候没有这个情况。

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • 请问下prometheus怎么进行自定义的按业

    请问下prometheus怎么进行自定义的按业

  • 节流函数为什么,点击无效,监听窗口大

    节流函数为什么,点击无效,监听窗口大

  • express访问静态资源失败

    express访问静态资源失败

  • IE 浏览器下 match 方法报错

    IE 浏览器下 match 方法报错

腾讯云代理商
海外云服务器