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

wordpress做的著名网站wordpress 浮动

wordpress做的著名网站,wordpress 浮动,织梦网站wap,番禺的互联网公司生产者没有成功把消息发送到MQ 丢失的原因 :因为网络传输的不稳定性,当生产者在向MQ发送消息的过程中,MQ没有成功接收到消息,但是生产者却以为MQ成功接收到了消息,不会再次重复发送该消息,从而导致消息的丢…

生产者没有成功把消息发送到MQ
丢失的原因 :因为网络传输的不稳定性,当生产者在向MQ发送消息的过程中,MQ没有成功接收到消息,但是生产者却以为MQ成功接收到了消息,不会再次重复发送该消息,从而导致消息的丢失。

解决办法 : 有两个解决办法:事务机制和confirm机制,最常用的是confirm机制(发布确认机制)。

注意:

          RabbitMQ的事务机制是同步的,很耗型能,会降低RabbitMQ的吞吐量。

          confirm机制是异步的,生成者发送完一个消息之后,不需要等待RabbitMQ的回调,就可以发送下一个消息,当RabbitMQ成功接收到消息之后会自动异步的回调生产者的一个接口返回成功与否的消息。

两个机制说明如下:

confirm(发布确认)机制
解释:RabbitMQ可以开启 confirm 模式,在生产者那里设置开启 confirm 模式之后,生产者每次写的消息都会分配一个唯一的 id,如果消息成功写入 RabbitMQ 中,RabbitMQ 会给生产者回传一个 ack 消息,告诉你说这个消息 ok 了。如果 RabbitMQ 没能处理这个消息,会回调你的一个 nack 接口,告诉你这个消息接收失败,生产者可以重新发送。而且你可以结合这个机制自己在内存里维护每个消息 id 的状态,如果超过一定时间还没接收到这个消息的回调,那么可以重发。

代码

yml配置

----------------------------------------------------------------------------------------------------

import lombok.extern.slf4j.Slf4j;
import org.springframework.amqp.rabbit.connection.CorrelationData;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.stereotype.Component;
/**
* 交换机回滚
*/
@Component
@Slf4j
public class ExchangeCallback implements RabbitTemplate.ConfirmCallback{/* correlationData 内含消息内容* ack 交换机接受成功或者失败。 true表示交换机接受消息成功, false表示交换机接受失败* cause 表示失败原因*/@Overridepublic void confirm(CorrelationData correlationData, boolean ack, String cause) {System.out.println("hello world");String id = correlationData.getId();String message = new String(correlationData.getReturnedMessage().getBody());if (ack){log.info("交换机收到消息id为{}, 消息内容为{}", id, message);}else {log.info("交换机未收到消息id为{}, 消息内容为{}, 原因为{}", id, message, cause);}}
}

----------------------------------------队列防止消息丢失----------------------------------------------------------------

import lombok.extern.slf4j.Slf4j;
import org.springframework.amqp.core.Message;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.stereotype.Component;/*** 队列防止消息丢失*/
@Slf4j
@Component
public class QueueCallback implements RabbitTemplate.ReturnCallback{@Overridepublic void returnedMessage(Message message,int replyCode, String replyText, String exchange, String routingKey) {log.info("消息 {} 经交换机 {} 通过routingKey={} 路由到队列失败,失败code为:{}, 失败原因为:{}",new String(message.getBody()), exchange, routingKey, replyCode, replyText);}
}

--------------------------引用->controller-----------------------------------------------

//交换机回滚
@Autowired
private ExchangeCallback exchangeCallback;
//队列回滚
@Autowired
private QueueCallback queueCallback;
/*** 初始化交换机监听*/
@PostConstruct
public void init(){  
//交换机
rabbitTemplate.setConfirmCallback(exchangeCallback);
/*** true:交换机无法将消息进行路由时,会将该消息返回给生产者* false:如果发现消息无法进行路由,则直接丢弃*/
rabbitTemplate.setMandatory(true);
//队列
rabbitTemplate.setReturnCallback(queueCallback);
}
/*** 发送消息* 结果:"这是一条消息"*/@GetMapping("/sendMessageTest")public String sendMessageTest(){// 消息类型为object 发送对象也是可以的String msg = "这是一条消息";// 第一个参数为发送消息到那个交换机上,第二个是发送的路由键(交换机进行需要符合绑定的队列),第三个参数为发送的消息
//CommonUtils.dirExchange--自己的交换机名称
//CommonUtils.routingKey --路由Key值 rabbitTemplate.convertAndSend("1235",CommonUtils.routingKey,msg);System.out.println("消息发送成功:"+msg);return "发送成功;发送内容为:"+msg;}

运行结果:

http://www.yayakq.cn/news/693659/

相关文章:

  • 高端开发网站哪家专业wordpress文字类主题
  • 什么网站专做衣服服装手机商城网站建设
  • 设计网站建设价格网站运行费用预算
  • 永春信息网站建设招标wordpress 多重筛选模板
  • 网站开发设计需求小说网站排名人气
  • 北京婚恋网站哪家最好阿里域名注册官网
  • 建设公司官方网站网站建设 东营远见网络公司
  • 开发型网站报价方法银河星宇 网站建设
  • 政协门户网站建设方案服务好 售后好的网站制作
  • 温州网站推广有哪些方法装修网站合作
  • 一键生成vi设计网站的优化公司
  • 怎样在网上做网站wordpress教程文档下载
  • 做的最好的网站小当网 绵阳网站建设
  • 免费的行情网站app代码数商云科技
  • 河南建设部网站wordpress shiftcv
  • 网站seo是干什么的群晖wordpress 手机
  • 文明网站的建设与管理几点思考建设银行官方网站入口
  • 展示网站方案app的开发流程是什么
  • 国土资源网站建设方案石家庄规划建设局网站
  • 大朗网站建设怎么推广效果好呢网站怎么做推广
  • 现代建设中国公司网站团队网站源码
  • ps外包网站wordpress改图片地址
  • 小城镇建设网站专做海报设计的网站
  • 平面设计接单赚钱吗充电宝关键词优化
  • 昆山做网站的公昆山做网站的公司司微信网站怎样做
  • 太原制作手机网站logo设计公司汉狮怎么样
  • 做网站设计制作的公司wordpress怎么汉化插件
  • 网站对应的ip网站标题符号有哪些
  • 郑州做网站kuihuakeji珠海网站建设尚古道策略
  • 做网站分辨率一般多少wordpress主题放在