rabbitMQ

ops/2024/9/25 8:21:49/

RabbitMQ 是一个开源的消息中间件,它实现了 AMQP(Advanced Message Queuing Protocol)协议,是一个可靠的、强大的分布式消息队列系统。

RabbitMQ 的主要特点包括:

  1. 可靠性:RabbitMQ 提供了持久化、消息确认、消息重试等机制,确保消息在发送、接收过程中不会丢失,可以保证系统的高可用性和可靠性。

  2. 灵活性:RabbitMQ 支持多种消息模式,包括点对点模式、发布/订阅模式、RPC(Remote Procedure Call)等。可以根据不同的应用场景选择合适的消息模式。

  3. 高性能:RabbitMQ 使用 Erlang 语言编写,具有优秀的并发性能和轻量级进程模型,能够处理高并发的消息传递。

  4. 易用性:RabbitMQ 提供了丰富的客户端库和可视化界面,方便开发人员进行消息的发送和接收,管理和监控队列等操作。

  5. 扩展性:RabbitMQ 支持集群部署,可以通过增加节点来扩展系统的处理能力,同时还支持插件机制,可以根据需要进行功能的扩展和定制。

RabbitMQ 可以广泛应用于分布式系统、微服务架构、消息驱动的应用等场景,提供了可靠的消息传递机制,帮助开发人员构建可靠、高性能的应用系统。

使用 IDEA 实现 RabbitMQ 的步骤:

打开 IDEA 并创建一个新的 Java 项目。

在项目的 pom.xml 文件中添加 RabbitMQ 的依赖,例如:

<dependencies><dependency><groupId>com.rabbitmq</groupId><artifactId>amqp-client</artifactId><version>5.12.0</version></dependency>
</dependencies>

在代码中创建一个 RabbitMQ 的连接和通道,例如:

import com.rabbitmq.client.ConnectionFactory;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.Channel;public class RabbitMQExample {private final static String QUEUE_NAME = "hello";public static void main(String[] args) throws Exception {// 创建连接工厂ConnectionFactory factory = new ConnectionFactory();factory.setHost("localhost"); // RabbitMQ 服务器的地址// 创建连接Connection connection = factory.newConnection();// 创建通道Channel channel = connection.createChannel();// 声明队列channel.queueDeclare(QUEUE_NAME, false, false, false, null);// 发送消息String message = "Hello, RabbitMQ!";channel.basicPublish("", QUEUE_NAME, null, message.getBytes("UTF-8"));System.out.println("发送消息: " + message);// 关闭通道和连接channel.close();connection.close();}
}

在 RabbitMQ 中,使用 rabbitTemplate 是一种方便的方式来发送和接收消息。rabbitTemplate 是 RabbitMQ 提供的一个高级 API,它封装了与 RabbitMQ 交互的细节,简化了发送和接收消息的操作。

 rabbitTemplate 的步骤:

添加 RabbitMQ 的依赖。在你的项目的 pom.xml 文件中添加以下依赖:

<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId></dependency>
</dependencies>

创建配置类,配置 RabbitMQ 的连接信息。在你的 Spring Boot 项目中,创建一个配置类,例如 RabbitMQConfig.java,并配置 RabbitMQ 的连接信息,例如:

import org.springframework.amqp.rabbit.connection.ConnectionFactory;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
public class RabbitMQConfig {@Beanpublic RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory) {RabbitTemplate rabbitTemplate = new RabbitTemplate(connectionFactory);// 可以设置相关的属性,例如消息的序列化方式、消息的确认模式等// rabbitTemplate.setXXX();return rabbitTemplate;}
}

在需要发送消息的地方注入 rabbitTemplate,并使用它发送消息。例如,在一个服务类中,你可以注入 rabbitTemplate 并使用它发送消息,例如:

import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;@Service
public class RabbitMQService {@Autowiredprivate RabbitTemplate rabbitTemplate;public void sendMessage(String exchange, String routingKey, Object message) {rabbitTemplate.convertAndSend(exchange, routingKey, message);}
}

在需要接收消息的地方注入 rabbitTemplate,并使用它接收消息。例如,在一个消息监听器类中,你可以注入 rabbitTemplate 并使用它接收消息,例如:

import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;@Component
public class RabbitMQListener {@Autowiredprivate RabbitTemplate rabbitTemplate;@RabbitListener(queues = "myQueue")public void handleMessage(Object message) {// 处理接收到的消息System.out.println("接收到消息: " + message);}
}

以上是在 RabbitMQ 中使用 rabbitTemplate 的基本步骤。你可以根据

运行代码,即可发送消息到 RabbitMQ 队列中。


http://www.ppmy.cn/ops/34443.html

相关文章

商场数据库项目MySQL实战(1——44)

我们在学习了MySQL基础语句后&#xff0c;终于迎来了第一次实战项目。 此次项目包含了88张商场可能用到的数据库表单&#xff0c;以便于商场的日常运行&#xff0c;并记录商场的各项数据。 通过表单的设计和建立&#xff0c;商城项目可以有效地管理用户信息、商品信息、订单和…

Redis基本數據結構 ― Set

Redis基本數據結構 ― Set 介紹常用命令範例1. 將元素添加到集合2. 移除指定元素3. 獲取集合包含的所有元素4. 交集5. 聯集6. 差集 介紹 元素不能重複無序集合底層透過hash table實現 常用命令 命令功能SADD將元素添加到集合SREM從集合中移除元素SMOVE將元素從一個集合移動到…

Go语言的包管理工具go mod与之前的GOPATH有什么区别?

在深入探讨Go语言的包管理工具go mod与之前的GOPATH之间的区别之前&#xff0c;我们首先需要理解这两个概念各自的作用和背景。 GOPATH时代 在Go语言早期版本中&#xff0c;GOPATH是一个非常重要的环境变量。它告诉Go工具链在哪里查找你的Go代码、第三方库以及编译后的二进制…

git 配置相关

问题一&#xff1a;ssh-keygen -t ed25519 -C "Gitee SSH Key" 这个命令中的 ed25519 字符是什么意思&#xff1f; ssh-keygen 是一个用于生成SSH密钥的工具&#xff0c;SSH&#xff08;Secure Shell&#xff09;是一种网络协议&#xff0c;用于加密方式远程登录和其…

C++——list的特性及使用

list的特性 STL中的list是指带头双向循环列表&#xff0c;list每个元素的存储相互独立&#xff0c;因为其节点存储位置独立不连续&#xff0c;其插入和删除不需要挪动其他元素效率比起vector更高。但也因为存储空间不连续的问题&#xff0c;不能做到和vector一样的随机…

opencv基础篇 ——(十五)多边形与凸边型

概念 在计算机视觉和图像处理中&#xff0c;多边形和凸多边形是常用的几何形状描述方式。它们在描述对象的形状、边界或区域时非常有用。下面我将简要介绍它们的概念和特点&#xff1a; 多边形&#xff08;Polygon&#xff09;定义&#xff1a; 多边形是一个平面内的闭合图形&…

spring注解之——@Service

Spring框架中的注解Service用于将类标记为Spring应用程序上下文中的服务组件。它主要用于指示带注释的类充当应用程序中的服务层组件。 以下是关于注释的一些要点Service&#xff1a; 业务逻辑&#xff1a;通常&#xff0c;带有注释的类Service包含业务逻辑。这些类负责封装和…

string容器

目录 string函数的构造 string赋值操作 string字符串拼接 string字符串查找和替换 string字符串比较 string字符存取 string插入与删除 string字串 string函数的构造 #include<iostream> #include<cstring> using namespace std; void test01() {string s…