【RabbitMQ】写一个简单的生产者消费者应用

生产者和消费者在编写代码的时候的思想和RabbitMQ的核心概念中提到的这些基本保持一致。

1. 生产者代码

package rabbitmq;

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

import java.io.IOException;
import java.nio.charset.StandardCharsets;
import java.util.concurrent.TimeoutException;

public class ProducerDemo {
    public static void main(String[] args) throws IOException, TimeoutException {
        // 1.建立连接
        ConnectionFactory connectionFactory = new ConnectionFactory();
        connectionFactory.setHost("101.42.168.168");
        connectionFactory.setPort(5672);
        connectionFactory.setUsername("admin");// 用户名
        connectionFactory.setPassword("admin"); // 密码
        connectionFactory.setVirtualHost("guan");//虚拟主机
        Connection connection = connectionFactory.newConnection();
        //2. 开启通道
        Channel channel = connection.createChannel();
        //3.声明交换机 使用内置的交换机

        //4.声明队列
        /*
        * public com.rabbitmq.client.impl.AMQImpl.Queue.DeclareOk queueDeclare(String queue, boolean durable, boolean exclusive,
        *                                                                            boolean autoDelete, Map<String, Object> arguments)
        * 参数说明
        * queue: 队列名称
        * durable: 是否持久化.true-设置队列为持久化, 待久化的队列会存盘,服务器重启之后, 消息不丢失。
        * exclusive
        *               * 是否独占, 只能有⼀个消费者监听队列
        *               * 当Connection关闭时, 是否删除队列
        * autoDelete: 是否⾃动删除, 当没有Consumer时, ⾃动删除掉
        * arguments: ⼀些参数
        *
        * */
        channel.queueDeclare("queue1", true, false, false, null);
        //5.发送消息
        /*
        * void basicPublish(String exchange, String routingKey, BasicProperties props, byte[] body)
        *
        * 参数说明
        *
        * exchange:交换机名称
        * routingKey:内置交换机,routingKey和队列名称保持一致
        * props:属性配置
        * body:消息
         * */
        for (int i = 0; i < 10; i++) {
            String msg = "hello rabbitMQ"+ i;
            channel.basicPublish("","queue1",null,msg.getBytes(StandardCharsets.UTF_8));
        }

        //打印方便观察
        System.out.println("消息发送成功!即将关闭连接~");

        //6.资源释放
        //channel.close();
        //connection.close();
    }
}

 2. 消费者代码

package rabbitmq;

import com.rabbitmq.client.*;

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

public class ConsumerDemo {
    public static void main(String[] args) throws IOException, TimeoutException {
        //1.创建连接
        ConnectionFactory connectionFactory = new ConnectionFactory();
        connectionFactory.setHost("101.42.168.168");
        connectionFactory.setPort(5672);
        connectionFactory.setUsername("admin");
        connectionFactory.setPassword("admin");
        connectionFactory.setVirtualHost("guan");
        Connection connection = connectionFactory.newConnection();
        //2.创建channel
        Channel channel = connection.createChannel();
        //3.声明队列(可以省略),要求生产者已经声明好了队列
        channel.queueDeclare("queue1",true,false,false,null);
        //4.消费消息
        channel.basicConsume("queue1",true,new DefaultConsumer(channel){
            @Override
            public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
                System.out.println("接收到消息: " + new String(body));
            }
        });
        //5.释放资源
    }
}

3. 观察结果

运行生产者,和消费者,这里我都没有关闭连接,释放资源。生产中还是按照标准的要求将资源关闭。

# 生产者:向MQ发送消息

# 消费者 从MQ取消息

 代码我放在了我的码云上:登录 - Gitee.com

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小小小小关同学

你的支持就是我的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值