Kafka 分布式的单位是 Partition。如何保证消息有序,需要分几个情况讨论。
From: https://blog.csdn.net/chunlongyu/article/details/53977819
实际情况中: (1)不关注顺序的业务大量存在;(2)队列无序不代表消息无序。
第(2)条的意思是说: 我们不保证队列的全局有序,但可以保证消息的局部有序。举个例子: 保证来自同1个 order id 的消息,是有序的!
Kafka 中发送1条消息的时候,可以指定(topic, partition, key) 3个参数。partiton 和 key 是可选的。如果你指定了 partition,那就是所有消息发往同1个 partition,就是有序的。并且在消费端,Kafka 保证,1个 partition 只能被1个 consumer 消费。或者你指定 key(比如 order id),具有同1个 key 的所有消息,会发往同1个 partition。也是有序的。