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

网站建设实训作业/上海短视频培训机构

网站建设实训作业,上海短视频培训机构,品牌设计概念,网站建设的内容我们知道,RabbitMQ的消息最终是存储在Queue上的,而在Queue之前还要经过Exchange,那么这个过程中就有两个地方可能导致消息丢失。第一个是Producer到Exchange的过程,第二个是Exchange到Queue的过程。 为了解决这个问题&#xff0c…

我们知道,RabbitMQ的消息最终是存储在Queue上的,而在Queue之前还要经过Exchange,那么这个过程中就有两个地方可能导致消息丢失。第一个是Producer到Exchange的过程,第二个是Exchange到Queue的过程。
在这里插入图片描述
为了解决这个问题,有两种方案,一种是通过confirm机制,另外一种是事务机制,因为事务机制并不推荐,这里先介绍Confirm机制。

Publisher Confirm是一种机制,用于确保消息已经被Exchange成功接收和处理。一旦消息成功到达Exchange并被处理,RabbitMQ会向消息生产者发送确认信号(ACK)。如果由于某种原因(例如,Exchange不存在或路由键不匹配)消息无法被处理,RabbitMQ会向消息生产者发送否定信号(NACK)。

//启用Publisher Confirmschannel.confirmSelect();//设置Publisher Confirms回调channel.addConfirmListener(new ConfirmListener() {@Overridepublic void handleAck(long deliveryTag, boolean multiple) throws IOException {System.out.println("Message confirmed with deliveryTag:"+deliveryTag);//在这里处理消息确认}@Overridepublic void handleNack(long deliveryTag, boolean multiple) throws IOException {System.out.println("Message not confirmed with deliveryTag:"+deliveryTag);//在这里处理消息未确认}});

Publisher Returns机制与Publisher Confirms类似,但用于处理在消息无法路由到任何队列时的情况。当RabbitMQ在无法路由消息时将消息返回给消息生产者,但是如果能正常路由,则不会返回消息。

//启用Publisher Returnschannel.addReturnListener(new ReturnListener() {@Overridepublic void handleReturn(int replyCode, String replyTest, String exchange, String routingKey, AMQP.BasicProperties properties, byte[] body) throws IOException {System.out.println("Message returned with replayCode: "+replyCode);//在这里处理消息发送到Queue失败的返回}});

通过以上方式,我们注册了两个回调监听,用于在消息发送到Exchange或者Queue失败时进行异常处理。通常我们可以在失败时精心报警或者重试来保障一定能发送成功。

完整代码:

package com.example.demo.rabbitmq;import com.rabbitmq.client.*;import java.io.IOException;public class PublisherCallbacksExample {public static void main(String[] args) throws Exception{ConnectionFactory factory=new ConnectionFactory();factory.setHost("localhost");try(Connection connection=factory.newConnection();Channel channel=connection.createChannel()){//启用Publisher Confirmschannel.confirmSelect();//设置Publisher Confirms回调channel.addConfirmListener(new ConfirmListener() {@Overridepublic void handleAck(long deliveryTag, boolean multiple) throws IOException {System.out.println("Message confirmed with deliveryTag:"+deliveryTag);//在这里处理消息确认}@Overridepublic void handleNack(long deliveryTag, boolean multiple) throws IOException {System.out.println("Message not confirmed with deliveryTag:"+deliveryTag);//在这里处理消息未确认}});//启用Publisher Returnschannel.addReturnListener(new ReturnListener() {@Overridepublic void handleReturn(int replyCode, String replyTest, String exchange, String routingKey, AMQP.BasicProperties properties, byte[] body) throws IOException {System.out.println("Message returned with replayCode: "+replyCode);//在这里处理消息发送到Queue失败的返回}});String exchangeName = "my_exchange";String routingKey = "my_routing_key";String message = "Hello,RabbitMQ!";//发布消息到Exchangechannel.basicPublish(exchangeName,routingKey,true,null,message.getBytes());//等待Publisher Confirmsif (!channel.waitForConfirms()) {System.out.println("Message was not confirmed!");}//关闭通道和连接channel.close();}}
}

另外,这里如果发送到Queue之后,是否一定能持久化下来,是否一定不丢,这就是另外一个话题了。

http://www.jmfq.cn/news/5345659.html

相关文章:

  • 学校网站的建设目标是什么/google谷歌
  • 网站建设嘉兴/郑州全域静态管理
  • 马拉松网站建设/站长工具关键词排名怎么查
  • 网站建设领导讲话稿/百度seo排名软
  • 北京远程时代网站建设/百度站长中心
  • 品牌网站建设哪里有/软文广告经典案例300
  • 自己建设网站赚钱/电商软文广告经典案例
  • 网站建设与栏目设置/百度账号怎么改名字
  • 关于公路建设的网站/百度网址安全中心
  • 电子商务网站建设需要哪些步骤/百度竞价推广属于什么广告
  • 建设团购网站费用/电脑培训班
  • 网站建设与管理 答案/电商软文范例100字
  • 网站建设概况/推广软文是什么
  • 网站建设织梦源码/环球资源网官方网站
  • 自贡建设投资有限公司网站/宁波网站建设优化企业
  • 国外乡村建设网站/公司注册
  • o2o网站建设最好公司/网络营销相关工作岗位
  • 建设永久网站/免费做网站怎么做网站吗
  • 天河建设网站方案/永久免费客服系统有哪些软件
  • 南山网站建设乐云seo/厦门人才网最新招聘信息
  • 天津市党的基层组织建设信息系统网站/百度一对一解答
  • 集美建设局中心网站/互联网广告销售是做什么的
  • 邢台手机网站建设报价/成都网站优化平台
  • 网站建设中 英语/搜索到的相关信息
  • 专业网站建设软件开发/seo有些什么关键词
  • 宿州建设网站公司哪家好/建网站需要哪些步骤
  • ie浏览器打开建设银行网站/域名批量注册查询
  • 政府网站群建设和管理规定/互联网营销师怎么做
  • 邵阳网站建设优化/短信广告投放
  • 郑州企业微网站建设/网站制作工具有哪些