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

成都营销型网站建设推广电子商务网站开发与建设

成都营销型网站建设推广,电子商务网站开发与建设,网站开发 如何定位,网页制作需要学多久前言 消息从生产者发送到exchange, 再到 queue, 再到消费者。这个过程中有哪些有消息丢失的可能性呢#xff1f; 发送时丢失#xff1a; 生产者发送的消息未送达 exchange消息到达 exchange 后未到达 queue MQ 宕机#xff0c;queue将消息丢失consumer 接收到消息后未消费…前言 消息从生产者发送到exchange, 再到 queue, 再到消费者。这个过程中有哪些有消息丢失的可能性呢 发送时丢失 生产者发送的消息未送达 exchange消息到达 exchange 后未到达 queue MQ 宕机queue将消息丢失consumer 接收到消息后未消费就宕机 消息可靠性问题及其对应的解决方案: 场景publisher发送时丢失MQ消息丢失consumer消费问题解决方案生产者确认机制消息持久化消费者消息确认失败重试机制 下面我们先说一下publisher 发送时丢失的问题应该如何处理 生产者确认机制的理论说明 RabbitMQ 提供了 publisher confirm 机制来避免消息发送到MQ过程中丢失。消息发送到MQ以后, 会返回一个结果给发送者表示消息是否处理成功。结果有两种请求 publish-confirm, 发送者确认 消息成功投递到交换机返回ack消息未投递到交换机返回nack publish-return, 发送回执 消息投递到交换机但是没有路由到队列返回ACK, 及路由失败原因 注意: 确认机制发送消息时, 需要给每个消息设置一个全局唯一 id, 以区分不同消息避免ack 冲突 代码实现 下面基于SpringAMQP 实现的生产者确认机制 在 publisher 服务的 application,yml 中添加以下配置 spring:rabbitmq:publisher-confirm-type: correlated # 开启异步回调publisher-returns: truetemplate:mandatory: true配置说明: publish-confirm-type: 开启 publisher-confirm, 这里支持两种类型 simple: 同步等待 confirm 结果, 直到超时correlated: 异步回调, 定义ConfirmCallback, MQ 返回结果时会回调这个ConfirmCallback publish-returns: 开启 publish-return 功能同样是基于 callback 机制不过是定义 ReturnCallbcaktemplate.mandatory: 定义消息路由失败时的策略。true, 则调用ReturnCallback, false: 则直接丢弃消息 ConfirmCallBack是基于每条消息设置的所以需要一个全局唯一id 进行区分。 ReturenCallbcak 则是基于每个RabbitTemplate操作实例是一种全局性的回调。 由于每个 RabbitTemplate 只能配置一个 ReturnCallback, 因此需要在项目启动过程中配置: (这里可以实现ApplicationContextAware,它可以在SpringIOC 容器初始化的时候进行一些全局性回调的操作) Slf4j Configuration public class CommonConfig implements ApplicationContextAware {Overridepublic void setApplicationContext(ApplicationContext applicationContext) throws BeansException {// 获取 RabbitTemplate对象RabbitTemplate rabbitTemplate applicationContext.getBean(RabbitTemplate.class);// 配置 ReturnCallbackrabbitTemplate.setReturnCallback((message, replayCode, replayText,exchange, routingKey) - {// 记录日志log.error(消息发送到队列失败, 响应码:{}, 失败原因:{},交换机:{}, 路由key:{},消息:{},,replayCode, replayText, exchange, routingKey, message.toString());// 如果有需要的话,重发消息});}} } 为每条发送的消息指定消息 ID, 并编写对应的 ConfirmCallback public void testSendMessage2SimpleQueue() throws InterruptedException {// 1. 准备消息String message hello, spring amqp!;// 2. 准备CorrelationData// 2.1 消息idCorrelationData correlationData newCorrelationData(UUID.randomUUID().toString());// 2.2 准备 ConfirmCallbackcorrelationData.getFuture().addCallback(confirm - {// 判断结果if(confirm.isAck()){// ACKlog.debug(消息成功投递到交换机!消息ID:{},correlationData.getId());}else {// NACKlog.error(消息投递到交换机失败!消息ID:{}, correlationData.getId());// 重发消息}}, throwable - {// 记录日志log.error(消息发送失败, throwable);// 重发消息});// 3.发送消息rabbitTemplate.convertAndSend(amq.topic, asimple.test, message, correlationData); }总结 SpringAMQP 中处理消息确认的几种情况 publisher-confirm: 消息发送到 exchange, 返回 ack消息发送失败没有到达交换机返回 nack消息发送过程中出现异常没有收到回执 消息成功发送到 exchange, 但没有路由到 queue, 调用 ReturnCallback
http://www.w-s-a.com/news/163310/

相关文章:

  • 网站内页权重怎么查辽宁建设工程信息网怎么上传业绩
  • 丰都网站建设价格镇江网站制作费用
  • app手机网站建设黄网站建设定制开发服务
  • 百度网盘app下载徐州优化网站建设
  • 附近网站电脑培训班展台设计方案介绍
  • 河南便宜网站建设价格低上海高端室内设计
  • 保险网站有哪些平台wordpress会员vip购买扩展
  • 网站怎么做图片转换广州车陂网站建设公司
  • 下载flash网站网站设计书的结构
  • 水利建设公共服务平台网站放心网络营销定制
  • 设计网站过程wordpress+分页静态
  • 临海网站制作好了如何上线如果安装wordpress
  • 长沙 学校网站建设网站制作价格上海
  • 九江网站推广徽hyhyk1国家住房部和城乡建设部 网站首页
  • 阿克苏网站建设咨询动漫设计与制作属于什么大类
  • 网站编辑做多久可以升职wordpress版权修改
  • 网站开发维护成本计算国外外贸平台
  • 简单的招聘网站怎么做购物网站功能报价
  • 哪个网站做中高端衣服建设自己网站的流程
  • 网站建设概况做网站的是怎么赚钱的
  • 网站发布信息的基本流程现在都不用dw做网站了吗
  • 赣州热门网站深圳龙岗做网站的公司
  • 中国最大的建站平台广告传媒公司取名
  • 深圳网站设计公司专业吗学动漫设计后悔死了
  • 企业网站形象建设网站开发入职转正申请书
  • 网站设计步骤济南建设网中标公告
  • 石佛营网站建设wordpress关健词
  • 您的网站空间即将过期建站 discuz
  • 上海简站商贸有限公司福州哪家专业网站设计制作最好
  • 博客网站开发流程苏州专业做网站的公司哪家好