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

潍坊市网站制作网络推广营销方案免费

潍坊市网站制作,网络推广营销方案免费,哪里可以学网站建设,视频音乐网站怎样建设上一篇我介绍了RabbitMQ的基本交换机以及队列,不了解可以再回顾一下。 那么这就带来一个问题,我们在程序中添加一个中间件,把我们的消息依托给MQ,那么我们如何保证我们的消息在这个过程不会丢失。保证它的的可靠性,目…

上一篇我介绍了RabbitMQ的基本交换机以及队列,不了解可以再回顾一下。

那么这就带来一个问题,我们在程序中添加一个中间件,把我们的消息依托给MQ,那么我们如何保证我们的消息在这个过程不会丢失。保证它的的可靠性,目前主流从三个角度保证:生产者可靠性,MQ可靠性,消费者可靠性。

生产者可靠性:

所谓生产者可靠性就是我们如何保证将我们的消息从生产者将消息发送到队列或者消息的可靠性

 1. 重试机制

针对网络异常,连接中断,卡顿的自动重发。(萌芽阶段,与客户端的连接,还没有到交换机/d队列)

spring:rabbitmq:/....connection-timeout: 1s template:retry:initial-interval: 1000msmultiplier: 2max-attempts: 3

参数讲解

connetion-timeout连接时长,如果在这个时长内依旧没有连接成功就认为连接失败
initial-interval等待时长,第一次连接失败后多久重新重试
mutiplier等待倍数,结合initial-interval,计算下次等待时长,initial-interval=initial-interval*mutiplier
max-attempts最大重连次数

 

重连机制似乎看起来我们每个程序都需要配置一下,但实际上我们真是企业还是要慎重,因为我们的不断重连是阻塞式的。所以说在追求极度的高并发情况下,需要慎重使用,如果必须使用,我们应该优化参数值,比如连接次数,连接时长等参数值调整。

2. 回调机制

确认消息是否到投递到交换机以及是都正确路由(成长阶段,到达交换机/队列)

Confirm Callback策略

 确认消息是否成功到达交换机

spring:rabbitmq:/...publisher-confirm-type: correlate/none/simple

参数解释 

publisher-confirm-typeSpring AMQP 启用监听RabbitMQ 退回消息的机制
none关闭confirm机制
simple同步阻塞等待MQ回执消息
correlatedMQ异步回调方式返回回执消息

//创建关联数据
CorrelationData correlationData = new CorrelationData(UUID.randomUUID().toString());
// 使用Lambda设置确认回调
rabbitTemplate.setMandatory(true);
rabbitTemplate.setConfirmCallback((correlationData1, ack, cause) -> {
if (ack) {System.out.println("[消息确认] 成功 - ID: " + correlationData.getId());
} else {System.out.println("[消息确认] 失败 - ID: " + correlationData.getId() + ", 原因: " + cause);
}
});

Return Callback策略

确认消息是否被成功路由(异步等待回执消息)

spring:rabbitmq:/...publisher-returns: true
rabbitTemplate.setMandatory(true);
rabbitTemplate.setReturnsCallback(returnedMessage -> {//对于需要的接口泛型 接受一个参数 在{}体内写方法体System.err.println("消息投递失败");//...处理逻辑/});

MQ可靠性:

交换机持久化

队列持久化

 

消息持久化

在spring-amqp中消息默认持久化

发送非持久化消息

Message message = MessageBuilder.withBody("hello".getBytes(StandardCharsets.UTF_8)).setDeliveryMode(MessageDeliveryMode.NON_PERSISTENT) //PERSISTENT.build();

消息的持久化影响了我的MQ的吞吐量,同时保证了消息的可靠性。为了平衡可靠性性和性能,

RabbitMQ从 3.6版本 引入了惰性队列(lazy queue)。

让我们看一下为什么持久化是怎么影响性能的

如果我们的消息是持久化的,消息依旧会先存放在内存中,当我们的信息量达到一定程度后,服务器page out将消息扇出到磁盘中。这个时刻队列暂时无法接受消息,处于阻塞状态

为了避免从内存写入磁盘这段性能损失,lazy queue先将消息写入磁盘,然后根据消费者的读取速速,将消息扇出到内存中(最多2048条)。

RabbitMQ3.8版本及以下,如若使用多队列,需要手动配置。

从 RabbitMQ3.12 版本开始,所有队列都采用惰性队列,无法使用传统队列模式

消费者可靠性:

http://www.ds6.com.cn/news/45820.html

相关文章:

  • 网站加视频播放设计怎么做的semir是什么牌子衣服
  • 公司做网站需要什么资质产品推广计划
  • 吉林疫情最新消息长春疫情最新消息seo是什么部门
  • 常德本地网络论坛seo品牌
  • php做网站登陆验证网络推广外包哪家好
  • 甘肃自助建站系统怎么用网络推广怎么找客户资源
  • 网站 做实名认证b站软件推广大全
  • 俞润装饰做哪几个网站百度信息流怎么做效果好
  • 四川电子商务网站软文推广是什么意思?
  • 做国际贸易哪个网站好各种推广平台
  • 在线营销型网站品牌营销咨询公司
  • 做网站的入什么科目杭州seo培训
  • 网站运营技巧南宁seo排名优化
  • 现在做网站建设的公司多么老铁外链工具
  • 烟台门户网站建设企业建站免费模板
  • 网站mssql 导出数据下载安装
  • 网站检索功能怎么做seo搜索引擎优化价格
  • 广西网络公司网站建设网络培训系统
  • 网店推广软文范例宁波百度推广优化
  • 桥头仿做网站有什么平台可以发广告
  • 大型网站团队人数百度app 浏览器
  • 网站建设的标准化建设是什么赣州网站seo
  • 商务互联做网站怎么样企业网站系统
  • 自己搭建网站自媒体代运营
  • 网站服务器诊断最佳磁力吧ciliba磁力链
  • 福州网站建设工作3分钟搞定网站seo优化外链建设
  • 建设网站的网站windows优化大师下载安装
  • acm网站免费做百度网盘账号登录入口
  • 有没有专门建设网站的公司关键词排名怎么快速上去
  • wordpress query_posts参数seo优化搜索推广