当前位置: 首页 > article >正文

RabbitMQ基础篇之Java客户端快速入门

文章目录

      • 需求
      • 项目设置与依赖管理
      • 配置RabbitMQ的连接信息
      • 创建队列与消息发送
      • 创建消费者(消息接收)
      • 环境准备与操作

需求

  • 利用控制台创建队列 simple.queue
  • 在 publisher 服务中,利用 SpringAMQP 直接向 simple.queue 发送消息
  • 在 consumer 服务中,利用 SpringAMQP 编写消费者,监听 simple.queue 队列

在这里插入图片描述



项目设置与依赖管理

  • 在实际项目中,通常我们会使用 spring-boot-starter-amqp 来引入Spring AMQP的功能。
  • 项目中的依赖配置已经包含了RabbitMQ的相关依赖,所以不需要单独添加。
<!--AMQP依赖,包含RabbitMQ-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-amqp</artifactId>
</dependency>



配置RabbitMQ的连接信息

  • 配置RabbitMQ连接的地址、端口和虚拟主机信息,这些信息在 每个微服务的 application.yml 文件中进行设置。
  • 需要设置如下参数:
    • spring.rabbitmq.host:RabbitMQ服务器的IP地址或域名。
    • spring.rabbitmq.port:连接RabbitMQ的端口(通常为5672)。
    • spring.rabbitmq.virtual-host:RabbitMQ的虚拟主机。
    • spring.rabbitmq.usernamespring.rabbitmq.password:连接RabbitMQ的用户名和密码。
spring:
  rabbitmq:
    host: 192.168.100.212 # 主机名
    port: 5672  # 端口
    virtual-host: / # 虚拟主机
    username: nhuan # 用户名
    password: 123456 # 密码



创建队列与消息发送

  • 创建队列:在RabbitMQ控制台中创建一个简单的队列(如 simple.q)。
  • 发送消息
    • 使用Spring AMQP提供的 RabbitTemplate 发送消息。调用 convertAndSend 方法,其中需要指定队列名和消息内容。
    • 例子代码:
@Autowired
private RabbitTemplate rabbitTemplate;

@Test
public void testSimpleQueue() {
    // 队列名称
    String queueName = "simple.queue";
    // 消息
    String message = "Hello, Spring AMQP!";
    // 发送消息
    rabbitTemplate.convertAndSend("simple.queue", message);
}



创建消费者(消息接收)

  • 消费者用于监听队列并接收消息。
  • 创建一个类,并使用 @RabbitListener 注解标注接收方法,指定监听的队列名称。
  • 例子代码:
@Slf4j
@Component
public class SpringRabbitListener {

    @RabbitListener(queues = "simple.queue")
    public void listenSimpleQueueMessage(String message) throws InterruptedException {
        log.info("spring 消费者接收到的消息: " + message);
    }
}

  • 通过 @RabbitListener 注解,Spring会自动处理消息的接收和转换。
  • 运行ConsumerApplication,成功监测到消息





环境准备与操作

  • 在开发过程中,确保RabbitMQ服务已经启动并运行。
  • 消费者和生产者分别部署到不同的微服务中,通过队列进行消息交换。

http://www.kler.cn/a/459881.html

相关文章:

  • Redis 发布订阅(Pub/Sub)机制详解
  • 丢弃法hhhh
  • Android 系统 ActivityManager 系统层深度定制
  • Lua迭代器如何使用?
  • 珞珈一号夜光遥感数据地理配准,栅格数据地理配准
  • REST与RPC的对比:从性能到扩展性的全面分析
  • 【每日学点鸿蒙知识】RichText展示问题、slider组件内置间距、WebView性能优化、AVSession错误
  • 12.30 linux 文件操作,磁盘分区挂载
  • 【2024年-7月-13日-开源社区openEuler实践记录】探索 CPM4OSSP-UI:提升用户交互体验的开源宝藏
  • 软件测试 Linux 服务器监控命令的基本知识
  • 大模型—Ollama 结构化输出
  • C12.【C++ Cont】string类字符串的创建、输入、访问和size函数
  • 利用AI进行系统性能优化:智能运维的新时代
  • Docker搭建Jenkins
  • 【Elasticsearch】数据分布与路由机制
  • 无人机驾驶证对入伍有帮助吗?
  • linux 点对点语音通话及直播推流实践三:嵌入式无GUI Linux VoIP语音对讲方案
  • 在 Ubuntu 下通过 Docker 部署 Caddy 服务器
  • 深入理解Jsoup与Selenium:Java爬虫的双剑合璧
  • kafka开机自启失败问题处理
  • STM32高级 物联网之Wi-Fi通讯
  • docker django uwsgi 报错记录
  • [openGauss 学废系列]-熟悉openGauss体系结构-权限
  • Mono里运行C#脚本5—mono_file_map_open
  • 计算机专业硕士有哪些研究方向
  • 复杂的QVariant写入文件以及从文件中读入复原