作者回复: 关于重复的问题,建议让业务逻辑自己来做幂等性控制,总有什么ID能做幂等控制的。顺序,不管怎么样,我建议你都认为消息可能会乱序,消费者这里要考虑乱序的情况,比如处理某个订单的消息时有状态机之类的设计,已经推进到后面的状态了,这时再来个之前状态的消息,就直接忽略掉这个消息。
作者回复: 幂等表是一种常见的做法,因为幂等是和业务有紧密关系的,所以幂等表也是跟着业务走的,而不是千篇一律都是一样的。对于消息而言,不仅要考虑重复,还要考虑乱序,有时一条消息后续还有别的消息,后续的消息处理过了,那前面那条到晚了,也不能按原先逻辑处理,所以这些都要由业务系统来实现这些功能,MQ本身不应该介入在其中。
作者回复: 这个我们在课程开始时就有一张来自官网的图,当中Spring Cloud Data Flow就是CONNECT ANYTHING,用来连接万物的,你可以再到spring.io首页看看,主要用来打通各种数据的。如果是我的话,我还是会先看官方文档和指南,先了解概况的。