一.普通消息
对于普通消息,RocketMQ提供了三种发送方式:同步发送,可靠异步发送和单项发送。
1.同步发送
可靠同步发送指消息发送方发送数据后,在收到接收方的响应后才会发送下一个消息。
2.异步发送
可靠异步发送指发送方发出消息后,不等待接收方响应,接着发送下一个消息。发送方通过回调接口接收服务器响应,并对响应结果进行处理。
二.顺序消息
1.全局顺序消息
对于指定的Topic,所有消息按照严格的先进先出的顺序发布和消费。
比如竞拍时,价格相同的情况下,按照优先出价者得。
2.分区顺序消息
对于指定的Topic,所有消息根据key进行分区,同一个分区内的消息按照先进先出的顺序发布和消费。
比如同一个订单的创建,支付,退款,发货等流程按照当前订单的顺序来执行。
三.延时消息
生产者将消息发送到RocketMQ,延迟一定时间后才发送给消费者。
比如订单过期支付取消。
四.事务消息
通过RocketMQ的事务消息能达到分布式事务的最终一致性。
半事务消息:暂时不能投递的消息,生产者把消息发送到了RocketMQ,但是RocketMQ未收到生产者对消息的二次确认,此时该消息被标记为暂时无法消费的状态,即半事务消息。
消息回查:由于网络等问题,某个事务消息的二次确认丢失,RocketMQ通过扫描发现某条消息长期处于“半事