开发者社区 > 云原生 > Serverless > 正文

如果mq触发机制的情况下,选择同步调用,是不是就是 队列顺序执行了,事件ABCD同时触发,然后根据顺

如果mq触发机制的情况下,选择同步调用,是不是就是 队列顺序执行了,事件ABCD同时触发,然后根据顺序,先执行A,A结束后再执行B这种串联的执行顺序,理解的对么? 昨天的测试情况下来看到的现象是这样

展开
收起
飘飘斯嘉丽 2023-04-24 18:20:25 233 0
4 条回答
写回答
取消 提交回答
  • 值得去的地方都没有捷径

    您的理解基本是正确的。MQ触发机制中,如果选择同步调用,那么事件ABCD将按照队列顺序执行,即先执行A,A执行完毕后再执行B,以此类推。这种串联的执行顺序确保了事件的顺序性和一致性。

    但是需要注意的是,如果事件的执行时间过长,可能会导致队列的积压和延迟,从而影响后续事件的执行。因此,在设计MQ触发机制时,需要合理设置队列大小和超时时间,以确保系统的稳定性和可靠性。

    2023-04-25 08:08:13
    赞同 展开评论 打赏
  • 公众号:网络技术联盟站,InfoQ签约作者,阿里云社区签约作者,华为云 云享专家,BOSS直聘 创作王者,腾讯课堂创作领航员,博客+论坛:https://www.wljslmz.cn,工程师导航:https://www.wljslmz.com

    阿里云函数计算支持 MQ 消息触发器,您如果选择同步调用,会有以下的执行顺序:

    1、MQ 消息队列中有多条消息,触发了多次函数计算。

    2、函数计算按照消息的顺序依次执行,也就是按照先进先出的原则依次执行被触发的函数。

    3、在消息队列中一条消息的处理完成之后,函数计算会返回处理结果,并且从队列中删除该消息。然后才会开始处理在队列中排在该消息后面的下一条消息。

    因此,您的理解是正确的。在同步调用的情况下,函数计算会保证消息队列中的消息被按照顺序依次处理,且只有前一条消息处理完成之后才会开始处理下一条消息。这种方式可以确保消息在处理过程中的顺序性,避免了消息乱序导致的数据错误问题。

    2023-04-25 08:23:53
    赞同 展开评论 打赏
  • 在消息队列(MQ)触发机制下,如果选择同步调用,一般情况下确实会按照队列中的顺序依次执行消息,因为同步调用会等待前一个消息处理完毕后再处理下一个消息。事件ABCD同时触发时,如果它们被放入同一个队列中,那么处理顺序就是A、B、C、D。也就是说,先处理第一个消息,处理完毕后再处理第二个消息,以此类推。

    需要注意的是,如果您的消息队列中有多个分区或者多个消费者,那么处理顺序可能会发生变化,因为不同分区或者消费者的处理速度可能不同。此时,消息处理的顺序就不一定是按照放入队列的顺序进行了。如果您需要确保顺序性,可以在消息中添加序列号等标识,然后在消息处理时按照序列号进行排序。

    另外,需要注意的是,同步调用可能会导致处理速度变慢,因为每个消息的处理都需要等待前一个消息处理完毕后才能开始。如果您的业务场景允许,可以考虑使用异步调用,这样可以提高消息处理的并发性能,缩短处理时间。

    2023-04-24 19:45:50
    赞同 展开评论 打赏
  • 目前没这个功能 不能严格保证顺序 有计划会做哈。

    此答案来自钉钉群“阿里函数计算官网客户"

    2023-04-24 19:34:30
    赞同 展开评论 打赏

快速交付实现商业价值。

相关电子书

更多
RocketMQ Client-GO 介绍 立即下载
RocketMQ Prometheus Exporter 打造定制化 DevOps 平台 立即下载
基于 RocketMQ Prometheus Exporter 打造定制化 DevOps 平台 立即下载