6.RabbitMQ 可靠性机制

本文详细介绍了RabbitMQ中的消息确认机制,包括发送ACK和消费ACK的过程。通过示例代码展示了如何使用confirmSelect()和basicAck()方法确保消息可靠地发送和接收,以及如何处理未确认的消息。

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

1. 使用事物

感觉一般用不到 不想研究

2. 发送ACK

发送ack机制保证了消息能够存储到队列中,但是由于需要等待确认 势必会对性能产生影响

try {
            // 获取连接
            Connection connection = factory.newConnection();
            // 创建一个通道
            Channel channel = connection.createChannel();
            // 定义一个队列
            channel.queueDeclare(QUEUE_NAME, false, false, false, arguments);
            // 定义一个消息
            String message = "Hello World!";
            // 开启消息确定
            channel.confirmSelect();
            // 发布一条消息
            channel.basicPublish("", QUEUE_NAME, null, message.getBytes());
            // 等待消息发布成功确定
            while(channel.waitForConfirms()){
                System.out.println(" [x] Sent '" + message + "'");
            }

        } catch (TimeoutException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }

3. 消费ACK

    // 创建连接工厂
    ConnectionFactory factory = new ConnectionFactory();
    // 设置ip
    factory.setHost("127.0.0.1");
    // 设置端口
    factory.setPort(AMQP.PROTOCOL.PORT);
    // 设置用户名
    factory.setUsername("guest");
    // 设置密码
    factory.setPassword("guest");

    // 新建一个长连接
    Connection connection = factory.newConnection();

    // 创建一个通道(一个轻量级的连接)
    Channel channel = connection.createChannel();

    // 声明一个队列
    String QUEUE_NAME = "queue.priority";
    System.out.println("Consumer Wating Receive Message");
    // 仅能获取100条未ack数据
    channel.basicQos(100);
    // 创建消费者
    Consumer consumer = new DefaultConsumer(channel){
        @Override
        public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
            String message = new String(body, "UTF-8");
            System.out.println(" [C] Received '" + message + "'");
            channel.basicAck(envelope.getDeliveryTag(),false); // ack
        }
    };

    // 订阅消息
    channel.basicConsume(QUEUE_NAME, false, consumer); //设置为不自动ack
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值