【RabbitMQ】RabbitMQ学习

news/2024/10/5 17:12:23 标签: java-ee, 数据库, java

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();
    }
}

http://www.niftyadmin.cn/n/5691076.html

相关文章

[uni-app]小兔鲜-07订单+支付

订单模块 基本信息渲染 import type { OrderState } from /services/constants import type { AddressItem } from ./address import type { PageParams } from /types/global/** 获取预付订单 返回信息 */ export type OrderPreResult {/** 商品集合 [ 商品信息 ] */goods: …

使用 Spring Boot 在电商平台中动态调整促销信息

业务背景 在电商平台上&#xff0c;促销活动是吸引用户的重要手段之一。然而&#xff0c;促销活动的状态&#xff08;如开始、结束&#xff09;可能会频繁变化&#xff0c;而这些变化需要实时反映在商品详情页上。如果每次促销状态改变都需要重新部署应用或者手动更改代码&…

FANUC机器人—PCDK

前言 FANUC提供了一种使用其 PC 开发人员套件 &#xff08;PCDK&#xff09; 从 PC 命令和配置机器人的简单方法。该套件允许 PC 访问机器人上的变量、寄存器、IO、程序、位置和警报&#xff1b;接下来&#xff0c;我将如何开始使用 C#。 连接到机器人 将以下突出显示的行添加…

Redis设计与实现 学习笔记 第五章 跳跃表

跳跃表&#xff08;skiplist&#xff09;是一种有序的数据结构&#xff0c;它通过在每个节点中维持多个指向其他节点的指针&#xff0c;达到快速访问节点的目的。 跳跃表支持平均O(logN)、最坏O(N)复杂度的节点查找&#xff0c;还可以通过顺序性操作来批量处理节点。 在大部分…

Hadoop HDFS命令操作实例

一.创建与查看HDFS目录 每次重启后&#xff0c;Jps和java -version执行出来的结果不符合就使用 source ~/.bash_profile 是在 Unix/Linux 系统上用来重新加载用户的 Bash 配置文件 ~/.bash_profile 的命令。这条命令的作用是使得当前的 Bash 环境重新读取并应用 ~/.bash_pro…

PhpStudy-PHP5.4.45后门漏洞应用程序(C++/base64/winhttp)

PhpStudy-PHP5.4.45后门漏洞应用程序&#xff08;C/base64/winhttp&#xff09; 前言引言&#xff08;时间回到多年前&#xff09; PhpShellCmd.exe使用介绍&#xff1a;&#xff08;1&#xff09;输入网址检测是否存在PHP/5.4.45&#xff08;2&#xff09;whoami&#xff08;3…

云原生(四十七) | PHP软件安装部署

文章目录 PHP软件安装部署 一、PHP软件部署步骤 二、安装与配置PHP PHP软件安装部署 一、PHP软件部署步骤 第一步&#xff1a;安装 EPEL 仓库 与 Remi仓库 第二步&#xff1a;启用 Remi 仓库 第三步&#xff1a;安装 PHP、PHP-FPM 第四步&#xff1a;启动并开机启用 PH…

在线计算FOC的kp ki

在FOC&#xff08;Field Oriented Control&#xff0c;磁场定向控制&#xff09;电流环中&#xff0c;KP&#xff08;比例增益&#xff09;和KI&#xff08;积分增益&#xff09;的计算是电流环参数整定的关键步骤。这两个参数的整定直接影响到电流环的响应速度、稳定性和精度。…