面试官:在消息队列里面有一批数据需要顺序执行,如何来保证?
面试官心理剖析:
主要看你有没有思考过这个问题?这个是常见的问题,看你有没有解决思路?
回答:
这里讲讲几个 MQ 是如何来保证消息的顺序性的。
1、rabbitMq
问题分析:
如图,data1 和 data2 是有顺序的,必须 data1 先执行,data2 后执行;这两个数据被不同的消费者消费到了,可能 data2 先执行,data1 后执行,这样原来的顺序就错乱了。
解决方案:
如图,在 MQ 里面创建多个 queue,同一规则的数据(对唯一标识进行 hash),有顺序的放入 MQ 的 queue 里面,消费者只取一个 queue 里面获取数据消费,这样执行的顺序是有序的。或者还是只有一个 queue 但是对应一个消费者,然后这个消费者内部用内存队列做排队,然后分发给底层不同的 worker 来处理。
2、kafka
问题分析:
如图,在 kafka 中,你对数据指定某个 key,那么这些数据会到同一个 partition 里面,在 partition 里面这些数据是有顺序的。从这里看没啥问题,插入到数据库的数据都是有序的。