前文
简单队列的不足
耦合性高,生产者一一对应消费者(如果想有多个消费者消费队列中的消息就不 OK 了)
队列名变更的话,这时候得同时变更(耦合性高)
WorkerQueue(工作队列)
什么是工作队列的呢?就是一个生产者对应多个消费者

- P : 表示生产者
- 中间的:表示队列
- C : 表示消费者
为什么会出现工作队列?
Simple 队列是一一对应的,而且我们实际开发中,生产者发送消息是毫不费力的,而消费者一般是要跟业务相结合的,消费者接收到消息之后就需要处理,可能需要花费时间,这时候队列就会积压了很多消息
连接配置
package com.java.rabbitmq.util;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
import java.io.IOException;
import java.util.concurrent.TimeoutException;
/**
* @author Woo_home
* @create 2020/5/26 11:18
*/
public class ConnectionUtils {
/**
* 获取 MQ 的连接
* @return
*/
public static Connection getConnection() throws IOException, TimeoutException {
// 定义一个连接工厂
ConnectionFactory factory = new ConnectionFactory();
// 设置服务地址
factory.setHost("localhost");
// 设置端口号(AMQP)
factory.setPort(5672);
// 设置 virtual hosts
factory.setVirtualHost("/vhost");
// 设置用户名
factory.setUsername("admin");
// 设置密码

本文深入探讨RabbitMQ中的工作队列概念,通过实例展示如何实现一个生产者对多个消费者的模型,解决简单队列的不足,如耦合性和消息积压问题。通过代码示例,介绍了如何配置RabbitMQ连接、创建生产者和消费者,以及测试工作队列的运行情况。
最低0.47元/天 解锁文章
1007

被折叠的 条评论
为什么被折叠?



