kafka的特性
1.kafka中,写入一个partion照片中的数据是必定有顺序的
2.kafka中一个消费者消费一个partion的数据,消费者取出数据时,也是有顺序的数据库
须要顺序的场景
1.数据库中的binlog
2.一些业务须要,好比但愿把某个订单的数据写入一个partion线程
为什么消息会错乱
1.因为消费者消费消息以后,消费以后,有可能交给不少个线程去处理数据(以下图),这样就致使数据顺序错乱 blog
解决办法队列
为了保证一个消费者中多个线程去处理时,不会使得消息的顺序被打乱,则能够在消费者中,消息分发至不一样的线程时,加一个队列,消费者去作hash分发,将须要放在一块儿的数据,分发至同一个队列中,最后多个线程从队列中取数据,以下图所示。kafka