【RabbitMQ】RabbitMQ学习

1. 发送流程

  1. 生产者 - connection - channel - 交换机 - 对列- channel - connection - 消费者

2. 工作模式

2.1. 简单模式(点对点)

一个消费者一个生产者,直接进行通信。

2.2. 工作对列模式

    1. 多个消费者共同消费消息对列中的消息。
    2. 同一条消息只能被一个消费者消费。

2.3. 发布订阅模式

这个模式中,多了一个 exchange host 角色

    1. 可以将消息传给所有对列。
    2. 同一条消息所有的消费者都能消费。

2.3.1. 定向模式(Direct\Routing)

    1. 通过 Binding Key 对于交换机和对列进行绑定

2.3.2. 通配符模式(Topic)

    1. 是路由模式的升级。
    2. 可以使用通配符对于 Routing Key 进行模糊映射。
    3. *表示一个字符,#表示多个字符

2.3.3. 广播模式(Fanout)

2.4. 发布确认模式

    1. 服务器会在收到生产者发送的消息后,向生产者发送 ACK,表示自己收到消息了。
    2. 常用于安全性需求高的场景。

2.5. RPC模式

    1. 一个客户端一个服务端
    2. 通过两个对列进行

3. 交换机的类型

3.1. 广播(fanout)

是发布订阅模式。

一个交换机,将消息转发到于其绑定的所有对列,每个消费者都能享有这些消息。

3.2. 定向(dirct)

根据routing key ,会发送给 binding Key 符合的对列。

3.3. 通配符(topic)

将消息转发给 和带有通配符的 binding key 的对列。

3.4. headers类型

根据消息内容进行匹配,消息内容中有headers内容进行匹配,

发送消息的时候,使用的是 Routing Key

传到对列的时候,使用的是 Binding Key

4. 代码流程

  1. 创建连接
  2. 创建 Channel 通道
  3. 声明 Exchange host 交换机
  4. 声明 Queue 对列
  5. 发送消息
  6. 消费消息
  7. 释放资源

代码:

复制代码
package org.example.work;

import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
import org.example.constant.Constants;

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

public class ProducerDemo {
    public static void main(String[] args) throws IOException, TimeoutException {
        // 1. 初始化
        ConnectionFactory connectionFactory = new ConnectionFactory();
        connectionFactory.setHost(Constants.HOST);
        connectionFactory.setPort(Constants.PORT);
        connectionFactory.setUsername(Constants.USER_NAME);
        connectionFactory.setPassword(Constants.PASSWORD);
        connectionFactory.setVirtualHost(Constants.VIRTUAL_HOST);

        // 2. 创建connection
        Connection connection = connectionFactory.newConnection();

        // 3. 创建channel
        Channel channel = connection.createChannel();

        // 4. 创建exchange host(如果需要的话)
        // TODO

        // 5. 声明queue
        channel.queueDeclare(Constants.WORK_QUEUE_NAME, true, false,false,null);

        // 6. 发送消息

        for (int i = 0; i < 10; i++) {
            String msg = "hello work mode..." + (i);
            channel.basicPublish("",Constants.WORK_QUEUE_NAME, null, msg.getBytes());
        }

        // 7. 释放资源
        channel.close();
        connection.close();
    }
}
相关推荐
serve the people2 分钟前
python环境搭建 (十二) pydantic和pydantic-settings类型验证与解析
java·网络·python
lekami_兰17 分钟前
Java 并发工具类详解:4 大核心工具 + 实战场景,告别 synchronized
java·并发工具
有位神秘人22 分钟前
Android中Notification的使用详解
android·java·javascript
云小逸26 分钟前
【nmap源码学习】 Nmap网络扫描工具深度解析:从基础参数到核心扫描逻辑
网络·数据库·学习
肉包_51135 分钟前
两个数据库互锁,用全局变量互锁会偶发软件卡死
开发语言·数据库·c++
霖霖总总1 小时前
[小技巧64]深入解析 MySQL InnoDB 的 Checkpoint 机制:原理、类型与调优
数据库·mysql
tb_first1 小时前
LangChain4j简单入门
java·spring boot·langchain4j
独自破碎E2 小时前
【BISHI9】田忌赛马
android·java·开发语言
范纹杉想快点毕业2 小时前
实战级ZYNQ中断状态机FIFO设计
java·开发语言·驱动开发·设计模式·架构·mfc
此刻你2 小时前
常用的 SQL 语句
数据库·sql·oracle