使用SpringAMQP实现工作消息队列功能

导读:本篇文章讲解 使用SpringAMQP实现工作消息队列功能,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

1、在工程中引入spring-amqp的依赖

<!--AMQP依赖,包含RabbitMQ-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-amqp</artifactId>
</dependency>

2、消息发送

2.1 首先配置MQ地址,在发送消息模块中的application.yml中添加配置:

spring:
  rabbitmq:
    host: 192.168.150.101 # 主机名
    port: 5672 # 端口
    virtual-host: / # 虚拟主机
    username: itcast # 用户名
    password: 123321 # 密码

2.2 然后在发送消息模块中编写测试类SpringAmqpWorkTest,并利用RabbitTemplate实现消息发送:

package cn.itheima.mq.helloworld;

import org.junit.jupiter.api.Test;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

/**
 * 发送消息测试类
 *
 * @author ning
 * @since 2022/12/2 20:09
 */

@SpringBootTest
public class SpringAmqpWorkTest {

    //注入收发消息模板
    @Autowired
    private RabbitTemplate rabbitTemplate;

    @Test
    void testSimpleWorkQueue() {
        //消息
        String msg = "hello, spring amqp!-";
        //队列名称
        String queueName = "simple.queue";
        for (int i = 1; i <= 100; i++) {
            //发送消息,转成字节数组发送
            rabbitTemplate.convertAndSend(queueName,msg + i);
        }

        System.out.println("消息发送完毕");
    }
}

3、接受消息(消费方/监听器)

3.1 首先配置MQ地址,在接受消息模块中的application.yml中添加配置:

spring:
  rabbitmq:
    host: 192.168.150.101 # 主机名
    port: 5672 # 端口
    virtual-host: / # 虚拟主机
    username: itcast # 用户名
    password: 123321 # 密码

3.2 然后在接受消息模块的listener包中新建一个类SpringWorkRabbitListener,代码如下:

package cn.itheima.mq.listener;

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

/**
 * 接收消息
 * 测试:工作模型(一个队列,可以由多个消费者平均消费)
 * @author ning
 * @since 2022/12/2 20:31
 */

@Component
public class SpringWorkRabbitListener {

    //声明要监听的队列
    //可以监听多个队列
    //监听一个:queues = ""
    //监听多个:queues = {""}
    @RabbitListener(queues = "simple.queue")
    public void listenWorkQueue1(String msg) {
        System.out.println("消费者1接受到了消息" + msg);
    }

    //声明要监听的队列
    //可以监听多个队列
    //监听一个:queues = ""
    //监听多个:queues = {""}
    @RabbitListener(queues = "simple.queue")
    public void listenWorkQueue2(String msg) {
        System.out.println("消费者2接受到了消息" + msg);
    }
}

使用SpringAMQP实现工作消息队列功能

以上消费者都是平均分配,这样不能实现能者多劳(有的机器性能好,有的机器性能差),如果想实现效率上的提升,只要让性能好的机器多处理,差的机器少处理,只需在消费模块配置以下配置即可:

spring:
  rabbitmq:
    listener:
      simple:
        prefetch: 1 # 每次只能获取一条消息,处理完成才能获取下一个消息

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之家整理,本文链接:https://www.bmabk.com/index.php/post/65882.html

(0)
小半的头像小半

相关推荐

极客之家——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!