【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();
    }
}
相关推荐
幸运的大号暖贴3 分钟前
解决Vibe Coding时Idea经常不自动git add问题
java·人工智能·git·intellij-idea·claudecode·opencode
m0_7162550012 分钟前
第一部分 数据开发 面试全题 模拟口述版(自问自答)
java·数据库·面试
L-影17 分钟前
常见的 ORM 工具
开发语言·数据库·fastapi·orm
噢,我明白了28 分钟前
MySQL常用指令--标准的电商/后台管理系统基础结构
数据库·mysql
2403_8832610930 分钟前
如何用 nodeType 与 nodeName 准确判断当前节点的物理类型
jvm·数据库·python
qq_4135020236 分钟前
如何利用 Block Tree 避免不必要的子组件重渲染?Vue3 编译黑科技
jvm·数据库·python
SuperherRo36 分钟前
服务攻防-Java组件安全&FastJson&高版本JNDI&不出网C3P0&编码绕WAF&写入文件CI链
java·安全·fastjson·waf·不出网·高版本·写入文件
丑八怪大丑40 分钟前
SQL数据类型
java·数据库·sql
m0_624578591 小时前
CSS定位如何实现多行文字垂直居中_通过绝对定位模拟表格
jvm·数据库·python
Nyarlathotep01131 小时前
并发集合类(3):LinkedBlockingQueue
java·后端