RabbitMQ系列(七)--批量消息和延时消息

批量消息发送模式

  批量消息是指把消息放到一个集合统一进行提交,这种方案设计思路是希望消息在一个会话里,比如放到threadlocal里的集合,拥有相同

的会话ID,带有这次提交信息的size等属性,最重要的是吧这一批消息进行合并。对于channel就是发送一次消息。这种方式也是希望消费端在消

费的时候,可以进行批量化的消费,针对一个原子业务的操作进行处理,但是不保证可靠性,需要进行补偿机制。

图例:

伪代码思路:
@Data
@AllArgsConstructor
@NoArgsConstructor
public class BatchMessage {
    private long sessionId;
    private List<String> messageHolder = new ArrayList<>();    //用来保存message的集合
    private int listSize;    //集合的条数
}

 

把message放到ThreadLocal里面使用,这些批量的消息需要同一个sessionId,如果要入库,只是保存sessionId对应的消息集合,而不是每条消息

步骤:

  1、首先业务数据入库

  2、将批量消息对应的BatchMessage入库,状态为发送中

  3、发送message到Broker

  4、返回confirm确认

  5、修改状态为消费成功

  6、。。。。后面不讲了,和之前博客思路一样

延迟消息发送模式

  在message实体的时候添加delayTime属性,这样就可以进行延迟发送

使用场景:

  1、在电商平台买到的商品签收后,不点击确认支付,系统自动在一定时间进行支付操作

  2、自动超时作废的场景,你的优惠券/红包也有使用时限,也可以用延迟消息机制

 

转载于:https://www.cnblogs.com/huigelaile/p/10929656.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值