rabbitMQ

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 的依赖,例如:

xml 复制代码
<dependencies>
    <dependency>
        <groupId>com.rabbitmq</groupId>
        <artifactId>amqp-client</artifactId>
        <version>5.12.0</version>
    </dependency>
</dependencies>

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

java 复制代码
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 文件中添加以下依赖:

xml 复制代码
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-amqp</artifactId>
    </dependency>
</dependencies>

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

java 复制代码
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 {
    
    @Bean
    public RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory) {
        RabbitTemplate rabbitTemplate = new RabbitTemplate(connectionFactory);
        // 可以设置相关的属性,例如消息的序列化方式、消息的确认模式等
        // rabbitTemplate.setXXX();
        return rabbitTemplate;
    }
}

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

java 复制代码
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class RabbitMQService {
    
    @Autowired
    private RabbitTemplate rabbitTemplate;
    
    public void sendMessage(String exchange, String routingKey, Object message) {
        rabbitTemplate.convertAndSend(exchange, routingKey, message);
    }
}

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

java 复制代码
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 {
    
    @Autowired
    private RabbitTemplate rabbitTemplate;
    
    @RabbitListener(queues = "myQueue")
    public void handleMessage(Object message) {
        // 处理接收到的消息
        System.out.println("接收到消息: " + message);
    }
}

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

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

相关推荐
茶杯梦轩4 小时前
从零起步学习RabbitMQ || 第三章:RabbitMQ的生产者、Broker、消费者如何保证消息不丢失(可靠性)详解
分布式·后端·面试
回家路上绕了弯2 天前
深入解析Agent Subagent架构:原理、协同逻辑与实战落地指南
分布式·后端
用户8307196840822 天前
Spring Boot 集成 RabbitMQ :8 个最佳实践,杜绝消息丢失与队列阻塞
spring boot·后端·rabbitmq
用户8307196840824 天前
RabbitMQ vs RocketMQ 事务大对决:一个在“裸奔”,一个在“开挂”?
后端·rabbitmq·rocketmq
初次攀爬者5 天前
RabbitMQ的消息模式和高级特性
后端·消息队列·rabbitmq
初次攀爬者7 天前
ZooKeeper 实现分布式锁的两种方式
分布式·后端·zookeeper
让我上个超影吧8 天前
消息队列——RabbitMQ(高级)
java·rabbitmq
塔中妖8 天前
Windows 安装 RabbitMQ 详细教程(含 Erlang 环境配置)
windows·rabbitmq·erlang
断手当码农8 天前
Redis 实现分布式锁的三种方式
数据库·redis·分布式
初次攀爬者8 天前
Redis分布式锁实现的三种方式-基于setnx,lua脚本和Redisson
redis·分布式·后端