RabbitMq基本配置使用

RabbitMq基本配置使用

RabbitMq的基本配置和使用(topicExchange)

一、RabbitMq

RabbitMQ是用Erlang语言编写的,实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)

1.所需包

<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>

二、MQ配置

yml配置

rabbitmq:
    host: 127.0.0.1
    username: guest
    password: guest
    virtual-host: /
    port: 8002
    listener:
      simple:
        retry:
          enabled: true

队列绑定配置

	public static final String CHARGEINFO_STATUS_QUEUE1 = "chargeInfo_status_queue1";
	public static final String CHARGEINFO_STATUS_QUEUE2 = "chargeInfo_status_queue2";
	public static final String CHARGEINFO_STATUS_EXCHANGE = "chargeInfo_status_exchange";
	public static final String CHARGEINFO_STATUS_ROUTING_KEY = "chargeInfo_status";
	public static final String DEAD_QUEUE_NAME = "dead_queue";
	public static final String DEAD_EXCHANGE_NAME = "dead_topic_exchange";
	public static final String DEAD_ROUTING_KEY = "#";
	// 本章采用主题交换机TopicExchange演示
	@Bean
    public Queue chargeRecordInfoQueue1() {
        Map<String, Object> map = new HashMap<>(2);
        // 消息过期时间 和消息过期处理叫交换机
        map.put("x-dead-letter-exchange", DEAD_EXCHANGE_NAME);
        map.put("x-message-ttl", MESSAGE_TTL);
        return new Queue(CHARGEINFO_STATUS_QUEUE1, true, false, false, map);
    }
    @Bean
    public Queue chargeRecordInfoQueue2() {
        Map<String, Object> map = new HashMap<>(2);
        map.put("x-dead-letter-exchange", DEAD_EXCHANGE_NAME);
        map.put("x-message-ttl", MESSAGE_TTL);
        return new Queue(CHARGEINFO_STATUS_QUEUE2, true, false, false, map);
    }
     @Bean
    public TopicExchange chargeRecordInfoTopicExchange() {
        return new TopicExchange(CHARGEINFO_STATUS_EXCHANGE);
    }
     @Bean
    public Binding chargeRecordInfoQueueAndTopicExchangeBinding() {
        return BindingBuilder.bind(chargeRecordInfoQueue1())
                .to(chargeRecordInfoTopicExchange())
                .with(CHARGEINFO_STATUS_ROUTING_KEY);
    }
    @Bean
    public Binding chargeRecordInfoQueueAndTopicExchangeBinding() {
        return BindingBuilder.bind(chargeRecordInfoQueue2())
                .to(chargeRecordInfoTopicExchange())
                .with(CHARGEINFO_STATUS_ROUTING_KEY);
    }
    // 过期消息处理队列绑定
	@Bean
    public Queue deadQueue() {
        return new Queue(DEAD_QUEUE_NAME);
    }
    @Bean
    public TopicExchange deadExchange() {
        return new TopicExchange(DEAD_EXCHANGE_NAME);
    }
    @Bean
    public Binding deadQueueAndExchangeBinding() {
        return BindingBuilder.bind(deadQueue())
                .to(deadExchange())
                .with(DEAD_ROUTING_KEY);
    }

二、MQ使用

mq发送

//(发送信息绑定交换机和路由键然后通过路由键将消息发送给符合此交换机的队列们)
// 无返回值发送消息
amqpTemplate.convertAndSend(RabbitmqConstant.CHARGEINFO_STATUS_EXCHANGE, RabbitmqConstant.CHARGEINFO_STATUS_ROUTING_KEY,
                msg);
// 有返回值发送消息
Object result = amqpTemplate.convertSendAndReceive(RabbitmqConstant.CHARGEINFO_STATUS_EXCHANGE, RabbitmqConstant.CHARGEINFO_STATUS_ROUTING_KEY, msg);

mq接收

	@RabbitListener(queues = CHARGEINFO_STATUS_QUEUE1)
    public void handlerMessage(ChargeRecordInfo chargeRecordInfo) {
    	// 执行逻辑处理
        this.onHandlerMessage(chargeRecordInfo);
    }
    @RabbitListener(queues = CHARGEINFO_STATUS_QUEUE2)
    public void handlerMessage(ChargeRecordInfo chargeRecordInfo) {
    	// 执行逻辑处理
        this.onHandlerMessage(chargeRecordInfo);
    }
    // 过期消息队列监听
    @RabbitListener(queues = DEAD_QUEUE_NAME)
	public void handlerMessage(Object message){
		// 过期消息处理
	}

发送完成两个队列监听器都可以收到 ,如果消费有效时间内未被处理过期后则会被过期队列监听到


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值