rabbitMq模式之简单模式 Hello Word

简单模式——生产者、消费者模式

一、生产者代码

点击查看代码
package com.example.rabbitmq.one;

import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;

import java.io.IOException;
import java.util.concurrent.TimeoutException;

/*
 * 生产者发消息
 * */
public class Producer {
    // 队列名称
    public static final String QUEUE_NAME = "hello";
    // 发消息
    public static void main(String[] args) throws IOException, TimeoutException {
        // 创建一个连接工厂
        ConnectionFactory factory = new ConnectionFactory();
        // 设置连接参数
        factory.setHost("localhost");
        factory.setUsername("guest");
        factory.setPassword("guest");
        // 创建连接
        Connection connection = factory.newConnection();
        // 创建获取信道
        Channel channel = connection.createChannel();
        /*
         * 生成一个队列
         * 1、队列名称
         * 2、队列里面的消息是否持久化(磁盘)默认情况消息存储在内存中
         * 3、该队列是否共一个消费者进行消费,是否进行消息共享,true可以多个消费者消费,false只能一个消费者消费
         * 4、是否自动删除,最后一个消费者断开链接后,该队列是否自动删除,true自动删除,false不自动删除
         * 5、其它参数
         * */
        channel.queueDeclare(QUEUE_NAME, false, false, false, null);
        String message = "hello world";
        /*
         * 发送一个消息
         * 1、发送到哪个交换机
         * 2、路由key是哪个,本次是队列的名称
         * 3、其他参数信息
         * 4、发送消息的消息体
         * */
        channel.basicPublish("", QUEUE_NAME, null, message.getBytes());
        System.out.println("消息发送完成......");
    }
}

发布消息:

消息发布成功:

二、消费者代码

点击查看代码
package com.example.rabbitmq.one;


import com.rabbitmq.client.*;

import java.io.IOException;
import java.util.Arrays;
import java.util.concurrent.TimeoutException;

/*
 * 消费者接收消息
 * */
public class Consumer {
    private static final String QUEUE_NAME = "hello";

    public static void main(String[] args) throws IOException, TimeoutException {
        ConnectionFactory factory = new ConnectionFactory();
        factory.setHost("localhost");
        factory.setUsername("guest");
        factory.setPassword("guest");
        Connection connection = factory.newConnection();
        Channel channel = connection.createChannel();
        // 声明 接收消息
        DeliverCallback deliverCallback = (consumerTag, message) -> {
            System.out.println("接收到消息:" + new String(message.getBody()));
        };
        // 取消消费的回调
        CancelCallback cancelCallback = (consumerTag) -> {
            System.out.println("消息消费被中断!");
        };
        /**
         * 消费者消费消息
         * 1、消费哪个队列
         * 2、消费成功之后是否自动应答 true自动应答,false不自动应答,代表手动应答
         * 3、消费者未成功消费的应答
         * 4、消费者取消消费的回调
         * */
        channel.basicConsume(QUEUE_NAME, true, deliverCallback, cancelCallback);
    }
}

接收消息:

消息被消费后:

三、提取公共方法

点击查看代码
package com.example.rabbitmq.rabbitMqUtils;

import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;

import java.io.IOException;
import java.util.concurrent.TimeoutException;

public class RabbitUtils {
    public static Channel getChannel() throws IOException, TimeoutException {
        // 创建一个连接工厂
        ConnectionFactory factory = new ConnectionFactory();
        // 设置连接参数
        factory.setHost("localhost");
        factory.setUsername("guest");
        factory.setPassword("guest");
        // 创建连接
        Connection connection = factory.newConnection();
        // 创建获取信道
        Channel channel = connection.createChannel();
        return channel;
    }
}

posted @ 2023-12-10 21:30  讨人厌的字  阅读(0)  评论(0编辑  收藏  举报