RabbitMQ入门之二:work消息模型

工作队列或者竞争消费者模式

在这里插入图片描述
工作队列,是rabbitMQ提供的5中消息模式中的第二种,工作队列,又称任务队列。简单来说就是一个生产者多个 多个消费者,生产者生产的消息将被多个消费者将平均分配。(但是性能强的消费者获取的OA的消息较多。)

接下来我们来模拟这个流程:

​ P:生产者:任务的发布者

​ C1:消费者,领取任务并且完成任务,假设完成速度较快

​ C2:消费者2:领取任务并完成任务,假设完成速度慢

面试题:避免消息堆积?

1) 采用workqueue,多个消费者监听同一队列。

2)接收到消息以后,通过线程池,异步消费。

1:代码编写
1:生产者与案例1中的几乎一样:
public class Send {
    private final static String QUEUE_NAME = "test_work_queue";

    public static void main(String[] argv) throws Exception {
        // 获取到连接
        Connection connection = ConnectionUtil.getConnection();
        // 获取通道
        Channel channel = connection.createChannel();
        // 声明队列
        channel.queueDeclare(QUEUE_NAME, false, false, false, null);
        // 循环发布任务
        for (int i = 0; i < 50; i++) {
            // 消息内容
            String message = "task .. " + i;
            channel.basicPublish("", QUEUE_NAME, null, message.getBytes());
            System.out.println(" [x] Sent '" + message + "'");

            Thread.sleep(i * 2);
        }
        // 关闭通道和连接
        channel.close();
        connection.close();
    }
}

不过这里我们是循环发送50条消息。

2.消费者1

在这里插入图片描述

3.消费者2

在这里插入图片描述

与消费者1基本类似,就是没有设置消费耗时时间。

这里是模拟有些消费者快,有些比较慢。

接下来,两个消费者一同启动,然后发送50条消息:

在这里插入图片描述

可以发现,两个消费者各自消费了25条消息,而且各不相同,这就实现了任务的分发。

2:能者多劳

刚才的实现有问题吗?

  • 消费者1比消费者2的效率要低,一次任务的耗时较长
  • 然而两人最终消费的消息数量是一样的
  • 消费者2大量时间处于空闲状态,消费者1一直忙碌

现在的状态属于是把任务平均分配,正确的做法应该是消费越快的人,消费的越多。

怎么实现呢?

我们可以使用basicQos方法和prefetchCount = 1设置。 这告诉RabbitMQ一次不要向工作人员发送多于一条消息。 或者换句话说,不要向工作人员发送新消息,直到它处理并确认了前一个消息。 相反,它会将其分派给不是仍然忙碌的下一个工作人员。

在这里插入图片描述

再次测试:

在这里插入图片描述

以上是RabbitMQ第二章work消息模型的代码。后序的消息模型代码,和整合SpringBoot,请查看我的博客目录。(在此推荐大家搜索http://yun.itheima.com/

黑马程序员。RabbitMQ文章是学习了黑马视频所写。)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值