RabbitMQ 学习笔记(二)

RabbitMQ 学习笔记(二)

Spring 整合RabbitMQ

  • 引入依赖

     <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-context</artifactId>
                <version>5.1.7.RELEASE</version>
            </dependency>
    
            <dependency>
                <groupId>org.springframework.amqp</groupId>
                <artifactId>spring-rabbit</artifactId>
                <version>2.1.8.RELEASE</version>
            </dependency>
    
            <dependency>
                <groupId>junit</groupId>
                <artifactId>junit</artifactId>
                <version>4.12</version>
            </dependency>
    
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-test</artifactId>
                <version>5.1.7.RELEASE</version>
     </dependency>
    
  • 配置文件

    rabbitmq.host = xxx.xxx.xxx.xxx
    rabbitmq.port = 5672
    rabbitmq.username = admin
    rabbitmq.password = admin
    rabbitmq.virtual-host = /api
    
  • 生产配置类

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xmlns:context="http://www.springframework.org/schema/context"
           xmlns:rabbit="http://www.springframework.org/schema/rabbit"
           xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans.xsd
           http://www.springframework.org/schema/context
           https://www.springframework.org/schema/context/spring-context.xsd
           http://www.springframework.org/schema/rabbit
           http://www.springframework.org/schema/rabbit/spring-rabbit.xsd">
        <!--加载配置文件-->
        <context:property-placeholder location="classpath:rabbitmq.properties"/>
    
        <!-- 定义rabbitmq connectionFactory -->
        <rabbit:connection-factory id="connectionFactory" host="xxx.xxx.xxx.xxx"
                                   port="${rabbitmq.port}"
                                   username="${rabbitmq.username}"
                                   password="${rabbitmq.password}"
                                   virtual-host="${rabbitmq.virtual-host}"/>
        <!--定义管理交换机、队列-->
        <rabbit:admin connection-factory="connectionFactory"/>
    
        <!--定义持久化队列,不存在则自动创建;不绑定到交换机则绑定到默认交换机
        默认交换机类型为direct,名字为:"",路由键为队列的名称
        -->
        <!--
            id:bean的名称
            name:queue的名称
            auto-declare:自动创建
            auto-delete:自动删除。 最后一个消费者和该队列断开连接后,自动删除队列
            durable:是否持久化
        -->
    
        <rabbit:queue id="spring_queue" name="spring_queue"    auto-declare="true"/>
    
        <!-- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~广播;所有队列都能收到消息~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -->
        <!--定义广播交换机中的持久化队列,不存在则自动创建-->
        <rabbit:queue id="spring_fanout_queue_1" name="spring_fanout_queue_1" auto-declare="true"/>
    
        <!--定义广播交换机中的持久化队列,不存在则自动创建-->
        <rabbit:queue id="spring_fanout_queue_2" name="spring_fanout_queue_2" auto-declare="true"/>
    
        <!--定义广播类型交换机;并绑定上述两个队列-->
        <rabbit:fanout-exchange id="spring_fanout_exchange" name="spring_fanout_exchange"  auto-declare="true">
            <rabbit:bindings>
                <rabbit:binding  queue="spring_fanout_queue_1"  />
                <rabbit:binding queue="spring_fanout_queue_2"/>
            </rabbit:bindings>
        </rabbit:fanout-exchange>
    
    
        <!-- 定义队列-->
        <rabbit:queue id="spring_direct_queue" name="spring_direct_queue"  auto-declare="true"/>
    
        <!--
          定义 Routing  路由模式 交互机
        -->
        <rabbit:direct-exchange name="spring_direct_exchange" >
            <rabbit:bindings>
                <!--direct 类型的交换机绑定队列  key :路由key  queue:队列名称-->
                <rabbit:binding queue="spring_direct_queue" key="info"></rabbit:binding>
            </rabbit:bindings>
    
        </rabbit:direct-exchange>
    
        <!-- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~通配符;*匹配一个单词,#匹配多个单词 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -->
        <!--定义广播交换机中的持久化队列,不存在则自动创建-->
        <rabbit:queue id="spring_topic_queue_star" name="spring_topic_queue_star"  auto-declare="true"/>
        <!--定义广播交换机中的持久化队列,不存在则自动创建-->
        <rabbit:queue id="spring_topic_queue_well" name="spring_topic_queue_well" auto-declare="true"/>
        <!--定义广播交换机中的持久化队列,不存在则自动创建-->
        <rabbit:queue id="spring_topic_queue_well2" name="spring_topic_queue_well2" auto-declare="true"/>
    
        <!--
          声明  topic 类型的交换机
        -->
        <rabbit:topic-exchange id="spring_topic_exchange"  name="spring_topic_exchange" auto-declare="true">
            <rabbit:bindings>
                <rabbit:binding pattern="baiqi.*"  queue="spring_topic_queue_star"/>
                <rabbit:binding pattern="baiqi.#" queue="spring_topic_queue_well"/>
                <rabbit:binding pattern="itcast.#" queue="spring_topic_queue_well2"/>
            </rabbit:bindings>
        </rabbit:topic-exchange>
    
        <!--定义rabbitTemplate对象操作可以在代码中方便发送消息-->
        <rabbit:template id="rabbitTemplate" connection-factory="connectionFactory"/>
    </beans>
    
  • 生产者

    @RunWith(SpringJUnit4ClassRunner.class)
    @ContextConfiguration(locations = "classpath:spring-rabbitmq-producer.xml")
    public class ProducerTest {
    
        //1.注入 RabbitTemplate
        @Autowired
        private RabbitTemplate rabbitTemplate;
    
        @Test
        public void testHelloWorld(){
            //2.发送消息
            rabbitTemplate.convertAndSend("spring_queue","hello world spring....");
        }
    
        /**
         * 发送fanout消息
         */
        @Test
        public void testFanout(){
            //2.发送消息
            rabbitTemplate.convertAndSend("spring_fanout_exchange","","spring fanout....");
        }
    
        @Test
        public void testDirect(){
            //2.发送消息
            rabbitTemplate.convertAndSend("spring_direct_exchange","info","spring Direct....");
        }
    
        /**
         * 发送topic消息
         */
        @Test
        public void testTopics(){
            //2.发送消息
            rabbitTemplate.convertAndSend("spring_topic_exchange","baiqi.hehe.haha","spring topic....");
        }
    }
    
  • 消费者配置类

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xmlns:context="http://www.springframework.org/schema/context"
           xmlns:rabbit="http://www.springframework.org/schema/rabbit"
           xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans.xsd
           http://www.springframework.org/schema/context
           https://www.springframework.org/schema/context/spring-context.xsd
           http://www.springframework.org/schema/rabbit
           http://www.springframework.org/schema/rabbit/spring-rabbit.xsd">
        <!--加载配置文件-->
        <context:property-placeholder location="classpath:rabbitmq.properties"/>
    
        <!-- 定义rabbitmq connectionFactory -->
        <rabbit:connection-factory id="connectionFactory" host="${rabbitmq.host}"
                                   port="${rabbitmq.port}"
                                   username="${rabbitmq.username}"
                                   password="${rabbitmq.password}"
                                   virtual-host="${rabbitmq.virtual-host}"/>
    
        <bean id="springQueueListener" class="com.baiqi.rabbitmq.listener.SpringQueueListener"/>
        <bean id="fanoutListener1" class="com.baiqi.rabbitmq.listener.FanoutListener"/>
        <!-- <bean id="fanoutListener2" class="com.baiqi.rabbitmq.listener.FanoutListener2"/>
        <bean id="topicListenerStar" class="com.baiqi.rabbitmq.listener.TopicListenerStar"/>
        <bean id="topicListenerWell" class="com.baiqi.rabbitmq.listener.TopicListenerWell"/>
        <bean id="topicListenerWell2" class="com.baiqi.rabbitmq.listener.TopicListenerWell2"/>
    -->
        <rabbit:listener-container connection-factory="connectionFactory" auto-declare="true">
           <rabbit:listener ref="springQueueListener" queue-names="spring_queue"/>
            <rabbit:listener ref="fanoutListener1" queue-names="spring_fanout_queue_1"/>
            <!--<rabbit:listener ref="fanoutListener2" queue-names="spring_fanout_queue_2"/>
            <rabbit:listener ref="topicListenerStar" queue-names="spring_topic_queue_star"/>
            <rabbit:listener ref="topicListenerWell" queue-names="spring_topic_queue_well"/>
            <rabbit:listener ref="topicListenerWell2" queue-names="spring_topic_queue_well2"/>-->
        </rabbit:listener-container>
    </beans>
    
  • 消费者

    public class SpringQueueListener implements MessageListener {
        @Override
        public void onMessage(Message message) {
            //打印消息
            System.out.println(new String(message.getBody()));
        }
    }
    
    
    
    public class FanoutListener implements MessageListener {
        @Override
        public void onMessage(Message message) {
            //打印消息
            System.out.println(new String(message.getBody()));
        }
    }
    
    
    public class TopicListenerWell implements MessageListener {
        @Override
        public void onMessage(Message message) {
            //打印消息
            System.out.println(new String(message.getBody()));
        }
    }
    
    // 消费者启动
    public class Test {
    
        public static void main(String[] args) {
            //初始化IOC容器
            ApplicationContext ctx = new ClassPathXmlApplicationContext("classpath:spring-rabbitmq-consumer.xml");
    
        }
    }
    

Spring boot 整合RabbitMQ

  • 引入依赖

  • 配置类application.yml

    # 配置RabbitMQ的基本信息  ip 端口 username  password..
    spring:
      rabbitmq:
        host:  # ip
        port: 5672
        username: admin
        password: handhand
        virtual-host: /api
    
  • 定义交换机,队列以及绑定关系的配置类

    @Configuration
    public class RabbitMqConfig {
    
        //定义交换机的名字
        public static final String  EXCHANGE_NAME = "boot_topic_exchange";
        //定义队列的名字
        public static final String QUEUE_NAME = "boot_queue";
    
        //1、声明交换机
        @Bean("bootExchange")
        public Exchange bootExchange(){
            return ExchangeBuilder.topicExchange(EXCHANGE_NAME).durable(true).build();
        }
    
        //2、声明队列
        @Bean("bootQueue")
        public Queue bootQueue(){
            return QueueBuilder.durable(QUEUE_NAME).build();
        }
    
        //3、队列与交换机进行绑定
        @Bean
        public Binding bindQueueExchange(@Qualifier("bootQueue") Queue queue, @Qualifier("bootExchange") Exchange exchange){
            return BindingBuilder.bind(queue).to(exchange).with("boot.#").noargs();
        }
    
    }
    
  • 注入RabbitTemplate,调用方法,完成消息发送

    @SpringBootTest
    @RunWith(SpringRunner.class)
    public class ProducerTest {
    
         //注入 RabbitTemplate
        @Autowired
         private RabbitTemplate  rabbitTemplate;
    
         @Test
         public void send(){
             rabbitTemplate.convertAndSend("boot_topic_exchange","boot.haha","boot mq...");
         }
    }
    
  • 消费者监听

    @Component
    public class RabbitMQListener {
    
          //定义方法进行信息的监听   RabbitListener中的参数用于表示监听的是哪一个队列
          @RabbitListener(queues = "boot_queue")
          public void ListenerQueue(Message message){
              System.out.println("message:"+message.getBody());
          }
    }
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值