Rabbit消息队列使用

由于项目使用Spring Cloud 分布式架构,整个项目拆分成多个子服务,每个服务服务之间出于设计需要,不互相依赖,需要服务和服务之间相互发消息。现在成熟的消息队列技术有很多,我们项目使用Rabbit MQ

@RabbitListener(bindings = @QueueBinding(
            value = @Queue(value = queueName, durable = "true", ignoreDeclarationExceptions = "true"),
            exchange = @Exchange(value = EventConfig.exchangeGR, type = ExchangeTypes.FANOUT, durable = "true"),
            key = "orderRoutingKey", ignoreDeclarationExceptions = "true"))
    public void save(@Payload GoodsReciptEvent event, Channel channel, @Header(AmqpHeaders.DELIVERY_TAG) long deliveryTag){
        log.info("SaveEvent: " + event.toString());
        try {
            channel.basicAck(deliveryTag, false);
        }catch (Exception e){
        
            log.info("event json -->"+JSONObject.toJSONString(event));
            try {
                channel.basicAck(deliveryTag, false);
            }catch (Exception ee){
                log.error("save failed !",e);
            }

        }

上面是项目java代码,只要rabbit环境已经安装好,依赖的jar包spring-rabbit-1.7.3.RELEASE.jar也引入进来,就可以正常发送接收消息。
有几个注意点,说明一下。
1、exchange = @Exchange(value = EventConfig.exchangeGR,
表示接收的交换器名称是EventConfig.exchangeGR,自己根据项目情况灵活配置上。
2、value = @Queue(value = queueName
表示接收的消息队列名称是queueName,自己根据项目情况灵活配置上。
3、type = ExchangeTypes.FANOUT
表示接收消息的类型,分为常用的三种FANOUT,广播模式,只要连接上,消息就全部通过接收到;DIRECT,直连模式,表示消息单独发;TOPIC,订阅模式,根据key匹配规则,匹配符合规则的消息数据
4、key=xxx,表示接收消息时候的key,TOPIC模式必须配置上
5、消息接收消费后,一定要channel.basicAck(deliveryTag, false)删除消息
在这里插入图片描述

上面截图是项目中rabbit消息队列的网页登录信息,可以看见当前消息是否阻塞,正常状态(Ready)的消息数量,阻塞的状态(Ucacked)数量。
注意:一般接收消息端,出现消息阻塞,服务重启后,阻塞消息就释放到正常状态,也可以根据情况,手动在界面上删除QUE。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值