【RabbitMQ 三】Java客户端开发

news2025/1/11 18:32:27

本文引用的代码源自《RabbitMQ实战指南》

关键的类和接口主要有Channel、Connection、ConnectionFactory、Consumer等,它们主要的作用如下:

  • Channel:实现AMQP协议层的操作
  • Connection:开启信道(Channel)、注册事件处理器、关闭连接

与RabbitMQ相关的开发工作,也主要围绕Channel、Connection这两个类展开

1.连接RabbitMQ:创建Connection

知道了RabbitMQ的IP地址、端口号、用户名、密码后,可以通过以下代码连接RabbitMQ,

在这里插入图片描述

2.创建信道

在创建完Connection以后,就建立了当前服务与RabbitMQ的连接。下一步就是使用Connection对象建立信道

Channel channel = conn.createChannel()

创建完Channel之后,可以使用Channel对象来发送、接收消息

注意:一个Connection可以创建多个Channel对象,但是Channel对象不是线程安全的。也就是说,最好为每个线程创建一个Channel

一般来说,调用connectionFactory.newConnection()或者connection.createChannel()以后,Connection和Channel就处于开启状态了。如果在后续使用channel的过程中,Connection或者Channel关闭了,程序会抛出异常

3.声明交换器、绑定队列

在绑定交换器和队列前,要确保先声明交换器和队列,即前两行所示

在这里插入图片描述

  • channel.exchangeDeclare是声明一个交换器。这里传入参数的意思是:声明一个名为exchangeName的交换器,交换器类型为direct,并且这是一个可持久化的交换器(第三个入参=true)。可持久化的意思是交换器信息会存入2磁盘,服务器重启后不会丢失交换器的信息

  • channel.queueDeclare是声明一个队列,不带任何入参是声明一个由RabbitMQ命名的、非持久化队列

  • channel.queueBind是绑定交换器和队列

既然交换器和队列存在绑定操作,也就必然存在解绑操作,可以通过queueUnbind方法来解绑

4.创建队列的时机

虽然RabbitMQ使用交换器和队列来处理消息,但因为消息只存储在队列中,所以交换器实际不消耗服务器资源,只有队列会消耗服务器资源

换句话说,是否在代码里创建队列也可以见仁见智:

  1. 动态创建:如果服务器资源充足,那么RabbitMQ官方建议生产者和消费者都应该显式建立队列。这样做可以确保交换器和队列是正确绑定匹配的(避免发送消息的交换器没有绑定任何队列、或者发送消息的路由键匹配不上队列,导致消息丢失)
  2. 静态创建:如果业务已经充分确定了队列长度,可以在上线前在服务器上以RabbitMQ命令创建好队列,这样业务层就不用再声明队列了

5.发送消息

发送消息可以使用channel.basicPulish方法,例如:

在这里插入图片描述

以上代码意思是:

  1. 将消息发送到exchangeName交换器汇总
  2. 交换器根据routingKey将消息存储到RabbitMQ的相应队列中
  3. 消息内容是messageBodyBytes

除了byte数组,还可以使用channel.basicPulish的重载方法,发送具有特殊格式的消息

6.消费消息

RabbitMQ有两种消费消息的方式:push(推)、pull(拉)

6.1 Push

Push模式下,消费者持续订阅队列,一般要实现Consumer接口或继承DefaultConsumer类

消费动作是调用channel.basicConsume来实现

在这里插入图片描述

以上调用channel.basicConsume的意思是:

  1. 从queueName队列中订阅消息
  2. autoAck=true时,消费者需要在接收到消息后显式地进行ack操作(调用channel.basicAck
  3. 当前消费者从队列中订阅消息的同时,也可能有其他消费者订阅相同的队列,使用consumerTag来区分多个消费者
  4. 最后一个入参,传入了一个DefaultConsumer的匿名实现类,这其实是消费者的回调方法。当消费者收到订阅队列的消息时,会执行重写的handleDelivery方法

6.2 Pull

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1649087.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

黑马点评项目总结

登录 基于session登录 短信验证码登录 配置登录拦截器 向 Spring MVC 框架中添加拦截器,LoginInterceptor 是一个自定义的拦截器,用于拦截用户的登录请求。 excludePathPatterns这一句是设置拦截器需要放行的请求路径列表。 "/user/code", …

ROS机械臂中Movelt!

Movelt!简介 一个易于集成使用的集成化开发平台 由一系列移动操作的功能包组成 1、运动规划 2、操作控制 3、3D感知 4、运动学 5、控制与导航算法 ....... 提供友好的GUI 可应用于工业、商业、研发和其他领域 ROS社区中使用度排名前三的功能包 Movelt!三大核心功能 …

Kafka应用Demo:按主题订阅消费消息

安装环境 Kafka安装可参考官方网站的指导(https://kafka.apache.org/quickstart), 按步骤解压压缩包,修改配置。然后再启动zookeeper和kafka-server即可。 需要注意的一点:如果是在VMware虚拟机上启动的kafka, 需要修改一下server.properties配置文件&am…

JavaEE技术之MySql高级-搭建主从复制(主从同步原理、一主多从配置)

文章目录 MySQL主从同步1、MySQL主从同步原理2、一主多从配置2.1、准备主服务器2.2、准备从服务器2.3、启动主从同步2.4、实现主从同步2.5、停止和重置2.6、常见问题问题1问题2 MySQL主从同步 1、MySQL主从同步原理 基本原理: slave会从master读取binlog来进行数据…

python中如何遍历字典

1. 遍历字典的键key ① >>> d{list:[1, 2, 3],1:123,111:python3,tuple:(4, 5, 6)} >>> for key in d:print(str(key):str(d[key])) list:[1, 2, 3] 1:123 111:python3 tuple:(4, 5, 6) ② >>> d{list:[1, 2, 3],1:123,111:python3,tuple:(4, 5, 6…

书生·浦语大模型实战营之手把手带你评测 Llama 3 能力(OpenCompass 版)

书生浦语大模型实战营之手把手带你评测 Llama 3 能力(OpenCompass 版) 环境配置 conda create -n llama3 python3.10 pytorch torchvision pytorch-cuda -c nvidia -c pytorch -y conda activate llama3conda install git git-lfs install✨下载 Llama3…

HP Z620 服务器打开VTx虚拟技术

在使用Virtual Box的时候,虚拟主机启动报错:提示需要VTx。于是到bios里面去设置VTx。 这里有个小坑,就是HP 的bios配置里面,VTx不在常规的“System Configuration”、“Advanced”等地方,而是在“Security”菜单里&…

nvcc: command not found

nvcc: command not found nvcc命令是 NVIDIA CUDA 编译器,就类似于gcc是c语言的编译器,用于编译 CUDA 代码并生成 GPU 可执行文件。由于程序是要经过编译器编程成可执行的二进制文件,而cuda程序有两种代码,一种是运行在CPU上的ho…

营销5.0时代,企业的痛如何解?

进入营销5.0阶段之后,许多企业都需解决连接客户效能低下的问题。针对这个问题,产品经理、软件开发公司包括个人开发者,要怎么找到有效的“解药”? 营销不仅每年都在变化,甚至每天都在变化。 ——现代营销学之父&…

js实现json数据可编辑

背景 项目中有低代码平台,由于历史脏数据和非同步编辑的问题,偶尔会出现数据错乱的问题,希望有一个快捷的方式修改数据 之前在用Formily的时候有注意到designable/react 里面的json数据编辑功能非常不错如果能应用到项目里就完美了 design…

《架构风清扬-Java面试系列第29讲》聊聊DelayQueue的使用场景

DelayQueue是BlockingQueue接口的一个实现类之一 这个属于基础性问题,老规矩,我们将从使用场景和代码示例来进行讲解 来,思考片刻,给出你的答案 1,使用场景 实现:延迟队列,其中元素只有在其预定…

图片编辑工具-Gimp

一、前言 GIMP(GNU Image Manipulation Program)是一款免费开源的图像编辑软件,具有功能强大和跨平台的特性。 GIMP作为一个图像编辑器,它提供了广泛的图像处理功能,包括但不限于照片修饰、图像合成以及创建艺术作品…

Day28:ElasticSearch入门、Spring整合ES、开发社区搜索功能

ElasticSearch入门 Elasticsearch简介 一个分布式的、Restful风格的搜索引擎。支持对各种类型的数据的检索(非结构化的也可以)。搜索速度快,可以提供实时的搜索服务。便于水平扩展(集群式部署),每秒可以处…

练习项目后端代码解析注解篇(annotation)

前言 本来想从接口处入手的,但是一下看到接口里几十个方法,眼睛有点抗拒,想想还是先看作者写的自定义注解吧。 项目里有三个自定义注解: 分别是AccessLimit注解、OperationLogger注解、VisitLogger注解 AccessLimit注解 这是一…

为什么下载卡在idealTree:NodeJS: sill idealTree buildDeps

可能使用的是npm config set registry https://registry.npm.taobao.org而这个镜像文件已经过期了 解决方法如下: 先使用 npm cache clean --force 清除缓存 再切换镜像源 再使用npm config get registry 进行查看是否换源成功 再使用 npm install -g vue/cli 就…

数据结构算法题day01

积累基本的写代码方式,其实都大同小异 王道、天勤、算法1800题、中选择 【day01】在带头节点的链表中,删除所有值为X的结点,并释放空间。 假设值为X的结点不唯一,试编写算法一实现上述操作。算法思路: a.首先找到x结点…

加速乐 js解混淆 __jsl_clearance_s生成

提示!本文章仅供学习交流,严禁用于任何商业和非法用途,未经许可禁止转载,禁止任何修改后二次传播,如有侵权,可联系本文作者删除! 目标网站 aHR0cHM6Ly9jcmVkaXQuaGVmZWkuZ292LmNuL2NyZWRpdC13…

nginx 启动,查看,停止

nginx 启动,查看,停止 启动 start nginx 查看是否启动成功 tasklist | findstr nginx 停止 nginx -s stop 测试配置文件的语法是否有误 nginx -t 重启nginx nginx-s reload

分享天某云对象存储开发的体验

最近体验了天某云对象存储的功能,作为一名资深开发者,开发体验差强人意,与阿里云存在一定的差距。 首先在开发文档上居然没有基于nodejs的代码示例,只有java,c#,go等的代码示例,虽然有javascript的,但那也只…