rabbitmq教程(三)

交换器

在rabbitmq中消息传递的核心思想是,生产者永远不会直接的发送一个消息到队列。实际上生产者甚至都不知道,消息是否会被传递到任何一个队列中。

相反,生产者只能发送消息到一个交换器上。交换器是一个很简单的玩意。一头儿接收生产者发送的信息,另一头儿把消息推送到队列中。交换器必须明确的知道,如何处理接收到的消息。应该把它添加到指定的队列?还是添加到多个队列?或者给销毁?这些规则交给交换器定义。


生产者->交换器->队列

rabbitmq一共有4个可用的交换器类型: directtopicheaders  和 fanout 。 默认交换器是 direct 。发布与订阅的实现使用第四个交换器类型 fanout
Config.java 首先配置FanoutExchange为一个bean。然后定义2个队列。再之后定义2个Binding把2个队列绑定到FanoutExchange交换器上。
package com.example.rabbitmq.test3;

import org.springframework.amqp.core.*;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import sun.text.bidi.BidiLine;

/**
 * 发布与订阅的实现使用交换器类型为fanout
 *
 * @author 刘仁楠
 * @date 2018/5/28 16:16
 */
@Configuration
public class Config {

    /**
     * 定义扇出(广播)交换器
     *
     * @author 刘仁楠
     * @date 2018/5/28 16:20
     */
    @Bean
    public FanoutExchange fanoutExchange() {
        return new FanoutExchange("fanout-exchange");
    }

    /**
     * AnonymousQueue这个类是代表一个匿名的、不耐用的、独占的、自动删除的队列
     *
     * @author 刘仁楠
     * @date 2018/5/28 16:19
     */
    @Bean
    public Queue autoDeleteQueue0() {
        return new AnonymousQueue();
    }

    @Bean
    public Queue autoDeleteQueue1() {
        return new AnonymousQueue();
    }

    /**
     * Binding这个类是一个简单的容器,用来搜集信息并描述绑定。
     * 把队列绑定到扇出(广播)交换器
     *
     * @author 刘仁楠
     * @date 2018/5/28 16:21
     */
    @Bean
    public Binding binding0(FanoutExchange fanoutExchange, Queue autoDeleteQueue0) {
        return BindingBuilder.bind(autoDeleteQueue0).to(fanoutExchange);
    }

    @Bean
    public Binding binding1(FanoutExchange fanoutExchange, Queue autoDeleteQueue1) {
        return BindingBuilder.bind(autoDeleteQueue1).to(fanoutExchange);
    }
}

接收广播的消息

package com.example.rabbitmq.test3;

import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;

/**
 * 接收广播的消息
 * @author 刘仁楠
 * @date 2018/5/28 16:23
 */
@Component
public class Receiver {

    @RabbitListener(queues = "#{autoDeleteQueue0.name}")
    public void receiver0(String str) {
        System.out.println("receiver0++++++++++:" + str);
    }

    @RabbitListener(queues = "#{autoDeleteQueue1.name}")
    public void receiver1(String str) {
        System.out.println("receiver1++++++++++:" + str);
    }
}
广播消息
package com.example.rabbitmq.test3;

import org.springframework.amqp.core.FanoutExchange;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

/**
 * 广播消息
 * @author 刘仁楠
 * @date 2018/5/28 16:25
 */
@Component
public class Send {

    @Autowired
    private FanoutExchange fanoutExchange;

    @Autowired
    private RabbitTemplate rabbitTemplate;

    public void send(){
        for (int i = 0; i < 5; i++) {
            rabbitTemplate.convertAndSend(fanoutExchange.getName(), "", "哈哈哈");
        }
    }
}

测试

package com.example.rabbitmq;

import com.example.rabbitmq.test3.Send;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

/**
 * @author 刘仁楠
 * @date 2018/5/28 16:26
 */
@RunWith(SpringRunner.class)
@SpringBootTest
public class RabbitmqApplicationTests3 {

    @Autowired
    private Send send;

    @Test
    public void send() throws Exception {
        send.send();
    }
}

运行结果

源码地址

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值