RabbitMQ work quene(工作队列模型) 1对n

此博客介绍了RabbitMQ的工作模型,包括如何实现消息的公平分配和消费者确认机制。生产者使用`basicPublish`发送消息到队列,而消费者通过设置`basicQos`限制一次仅处理一个消息,并使用`basicAck`手动确认消息已被消费。这样,处理速度快的消费者将优先获取新的消息,确保了消息处理的效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

work模型

默认:平均分配,无论处理速度,平均分配到每个队列
消费者: 可以设置消费者通道,让通道每次只进来一个消息,
关闭消费者通道的自动确认,让消息消费完一个,在开始下一个。谁消费的快,谁先拿消息走

生产者:

public void test() throws IOException, TimeoutException {
		// 连接对象被封装
        // 获取连接对象
        Connection connection = connectionFactory.newConnection();
        // 获取连接通道
        Channel channel = connection.createChannel();
		// 通过通道,声明队列
        channel.queueDeclare("hello",true,false,false,null);
		//生产消息        
		for(int i = 0;i<10;i++){
			channel.basicPublish("","hello",MessageProperties.PERSISTENT_TEXT_PLAIN,(i+  "内容").getBytes());
		}
		// 关闭通道
		channel.close();
		// 关闭连接
		connection .close();
    }

消费者1;

public void test() throws IOException, TimeoutException {
		// 连接对象被封装
        // 获取连接对象
        Connection connection = connectionFactory.newConnection();
        // 获取连接通道
        Channel channel = connection.createChannel();
		// 通过通道,声明队列
        channel.queueDeclare("hello",true,false,false,null);
        channe1.basicQos(1);
		//消费消息        
		// 第二个参数,false 不会自己动确认消息
		channel.basicConsume("hello",false,new DefaultConsumer(channel){
			@Override
			public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
				System.out.println("消费者1 : "+new String(body));
				// 传输1 : 确认队列中哪个具体消息
				// 参数2:是否开启多条消息同时确认
				channel.basicAck(envelope.getDeliveryTag(),false);
			}
		});
    }

消费者2;

public void test() throws IOException, TimeoutException {
		// 连接对象被封装
        // 获取连接对象
        Connection connection = connectionFactory.newConnection();
        // 获取连接通道
        Channel channel = connection.createChannel();
		// 通过通道,声明队列
        channel.queueDeclare("hello",true,false,false,null);
        channe1.basicQos(1);
		//消费消息        
		// 第二个参数,false 不会自己动确认消息
		channel.basicConsume("hello",fasle,new DefaultConsumer(channel){
			@Override
			public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
				System.out.println("消费者2 : "+ new String(body));
				// 传输1 : 确认队列中哪个具体消息
				// 参数2:是否开启多条消息同时确认
				channel.basicAck(envelope.getDeliveryTag(),false);
			}
		});
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值