RabbitMQ快速上手

RabbitMQ 概述

RabbitMQ是一个实现了 AMQP 的消息队列服务,是当前主流的消息中间件

MQ的作用

工作:接收并转发消息

1.异步解耦

2.流量削峰

3.消息分发

4.延迟通知

RabbitMQ 默认管理端口号15672

操作RabbitMQ 三种方式

1.通过代码来操作 5672

2.通过界面来操作 15672

3.通过命令操作 Rabbitmqctl

黄色区域的六个标签就代表六种不同角色

虚拟机类似于mysql 的 dataBase

生产者与消费者模型

生产者 会发送消息 通过connection 连接 发送消息到RabbitMQ 服务器中,交换机 就会将接收到的消息 存放到消息队列 中,消费者 就会通过connectio n连接RabbitMQ 服务器 去消费 消息队列中存放的消息

**connection:**连接,是客户端与服务器通过TCP相连接的,这个连接是消息传递的基础,负责传输客户端与服务器之间的数据和控制信息

channel:信道,通道,它是基于connection TCP,一个TCP可以有多个channel,每个channel都是独立的 虚拟连接,消息的传递和接收都是基于channl

**virtual Host :**虚拟主机,是为消息队列提供的 一种逻辑隔离手段

exchange :交换机,负责接收消息 根据特定的规则将消息 路由到一个或多个queue中

**queue:**消息队列,用于储存消息

建立连接所需要信息

1.ip

2.端口号

3.虚拟主机

4.账号

5.密码

具体实现代码如下可参考去理解

以下是生产者具体流程代码:

java 复制代码
//1.建立连接
        ConnectionFactory connectionFactory=new ConnectionFactory();
        connectionFactory.setVirtualHost("");//虚拟主机
        connectionFactory.setPort(5672);//端口号
        connectionFactory.setHost("");//ip
        connectionFactory.setPassword("");
        connectionFactory.setUsername("");
        Connection connection=connectionFactory.newConnection();//创建 连接
        //2.创建 信道
        Channel channel=connection.createChannel();
        //3.声明 交换机(在此不创建 使用内置的交换机)
       //4.声明队列
        channel.queueDeclare("hello",true,false,false,null);
        /**
         * queueDeclare(String queue, boolean durable, boolean exclusive, boolean autoDelete,
         *                                  Map<String, Object> arguments)
         *     queue :队列名称
         *     durable:是否可持久化
         *     exclusive:是否独占
         *     autoDelete:是否自动删除
         *     arguments:参数
         *
         */
        //5.传递消息
        String msg="hello,RabbitMQ";
        channel.basicPublish("","hello",null,msg.getBytes());
        /**
         * basicPublish(String exchange, String routingKey, BasicProperties props, byte[] body)
         * exchange:交换机名称//此处不写使用默认的交换机
         * routingKey:交换机与队列建立联系的,内置交换机🀄 routingKey与队列名称相同
         * props:属性配置
         * body:要发送的消息
         */
        //6.释放资源
//        channel.close();
//        connection.close();

以下的是消费者代码

java 复制代码
 //1.连接
        ConnectionFactory connectionFactory=new ConnectionFactory();
        connectionFactory.setHost("");
        connectionFactory.setUsername("");
        connectionFactory.setPassword("");
        connectionFactory.setPort(5672);
        connectionFactory.setVirtualHost("");
        //2.创建chenel
        Connection connection=connectionFactory.newConnection();
        Channel channel=connection.createChannel();
        //3.声明队列
        channel.queueDeclare("hello",true,false,false,null);

        //4.消费消息
        DefaultConsumer consumer=new DefaultConsumer(channel){
            @Override
            public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
//                super.handleDelivery(consumerTag, envelope, properties, body);
                System.out.println("接收到消息"+new String(body));
            }
        };
        channel.basicConsume("hello",true,consumer);
        /**
         * basicConsume(String queue, boolean autoAck, Consumer callback
         * queue 队列名称
         * autoAck:是否自动确认
         * callback:对消息具体的执行逻辑
         *
         */
        //等待程序打印完毕
        Thread.sleep(2000);

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

根据以上代码结合RabbitMQ界面化操作 ,可以很清晰的理解生产者与消费者模型

上述代码只是简单代码,其中一些信息 up删除了,大家复制代码时记得去补充,up自己的云服务器内容 不宜公开哈哈,希望 大家可以通过此篇博客大致了解一下 RabbitMQ是什么 具体更详细的敬请后期专栏内容

相关推荐
珠海西格5 小时前
“主动预防” vs “事后补救”:分布式光伏防逆流技术的代际革命,西格电力给出标准答案
大数据·运维·服务器·分布式·云计算·能源
小邓吖8 小时前
自己做了一个工具网站
前端·分布式·后端·中间件·架构·golang
曹天骄12 小时前
基于 Cloudflare Worker 构建分布式测速调度系统:KV 与 D1 数据层设计实战教程
分布式·缓存
Prince-Peng14 小时前
技术架构系列 - 详解Redis
数据结构·数据库·redis·分布式·缓存·中间件·架构
曹天骄16 小时前
基于 Cloudflare Worker + KV 构建高性能分布式测速调度系统(工程实战)
分布式
奋进的芋圆16 小时前
Spring Boot 3 高并发事务与分布式事务企业级完整解决方案
spring boot·分布式
淡泊if16 小时前
Kafka部署模式详解:从单机到分布式集群的核心选择
分布式·kafka
鱼跃鹰飞17 小时前
面试题:什么是时钟回拨问题?怎么解决
分布式·系统架构
无心水17 小时前
分布式环境下定时任务与SELECT FOR UPDATE的陷阱与解决方案
分布式·后端·wpf·xxl-job·quartz·定时任务·selectforupdate
缘友一世17 小时前
大模型分布式推理:Ray 与 vLLM/Transformers 的协同架构深度解析
分布式·架构·transformer·ray·vllm