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

店铺装修设计网站十大互联网广告公司

店铺装修设计网站,十大互联网广告公司,购买游戏软件做网站,家纺网站建设mq进阶 RabbitMQ 怎么避免消息丢失? 把消息持久化磁盘,保证服务器重启消息不丢失。 每个集群中至少有一个物理磁盘,保证消息落入磁盘。#RabbitMQ 的消息是怎么发送的? 首先客户端必须连接到 RabbitMQ 服务器才能发布和消费消息&…

mq进阶

RabbitMQ 怎么避免消息丢失?
把消息持久化磁盘,保证服务器重启消息不丢失。
每个集群中至少有一个物理磁盘,保证消息落入磁盘。
#RabbitMQ 的消息是怎么发送的?
首先客户端必须连接到 RabbitMQ 服务器才能发布和消费消息,客户端和 rabbit server 之间会创建一个 tcp 连接,一旦 tcp 打开并通过了认证(认证就是你发送给 rabbit 服务器的用户名和密码),你的客户端和 RabbitMQ 就创建了一条 amqp 信道(channel),信道是创建在“真实” tcp 上的虚拟连接,amqp 命令都是通过信道发送出去的,每个信道都会有一个唯一的 id,不论是发布消息,订阅队列都是通过这个信道完成的。

#RabbitMQ 集群中唯一一个磁盘节点崩溃了会发生什么情况?
如果唯一磁盘的磁盘节点崩溃了,不能进行以下操作:
不能创建队列
不能创建交换器
不能创建绑定
不能添加用户
不能更改权限
不能添加和删除集群节点
唯一磁盘节点崩溃了,集群是可以保持运行的,但你不能更改任何东西。

要保证消息持久化成功的条件有哪些?
声明队列必须设置持久化 durable 设置为 true.
消息推送投递模式必须设置持久化,deliveryMode 设置为 2(持久)。
消息已经到达持久化交换器。
消息已经到达持久化队列。
以上四个条件都满足才能保证消息持久化成功。
#RabbitMQ 持久化有什么缺点?
持久化的缺地就是降低了服务器的吞吐量,因为使用的是磁盘而非内存存储,从而降低了吞吐量。可尽量使用 ssd 硬盘来缓解吞吐量的问题。
RabbitMQ 节点的类型有哪些?
磁盘节点:消息会存储到磁盘。
内存节点:消息都存储在内存中,重启服务器消息丢失,性能高于磁盘类型。
RabbitMQ 集群搭建需要注意哪些问题?
各节点之间使用“–link”连接,此属性不能忽略。
各节点使用的 erlang cookie 值必须相同,此值相当于“秘钥”的功能,用于各节点的认证。
整个集群中必须包含一个磁盘节点。
RabbitMQ 每个节点是其他节点的完整拷贝吗?为什么?
不是,原因有以下两个:
存储空间的考虑:如果每个节点都拥有所有队列的完全拷贝,这样新增节点不但没有新增存储空间,反而增加了更多的冗余数据;
性能的考虑:如果每条消息都需要完整拷贝到每一个集群节点,那新增节点并没有提升处理消息的能力,最多是保持和单节点相同的性能甚至是更糟。
RabbitMQ 对集群节点停止顺序有要求吗?
RabbitMQ 对集群的停止的顺序是有要求的,应该先关闭内存节点,最后再关闭磁盘节点。如果顺序恰好相反的话,可能会造成消息的丢失。
RabbitMQ如何处理消息丢失 (重点)

首先明确一点 一条消息的传送流程:生产者->MQ->消费者

所以有三个地方都会丢失数据:

生产者发送给MQ的途中出现网络问题 MQ自己没保管好弄丢了 消费者拿到数据后出错了没有最终完成任务 依次分析

1)生产者弄丢了数据

生产者将数据发送到rabbitmq的时候,可能因为网络问题导致数据就在半路给搞丢了。

​ 发送回执确认(推荐) 可以开启confirm模式,在生产者那里设置开启confirm模式之后,你每次写的消息都会分配一个唯一的id,然后如果写入了rabbitmq中,rabbitmq会给你回传一个ack消息,告诉你说这个消息ok了。如果rabbitmq没能处理这个消息,会回调你一个nack接口,告诉你这个消息接收失败,你可以重试。而且你可以结合这个机制自己在内存里维护每个消息id的状态,如果超过一定时间还没接收到这个消息的回调,那么你可以重发。   事务机制和cnofirm机制最大的不同在于,事务机制是同步的,你提交一个事务之后会阻塞在那儿,但是confirm机制是异步的,你发送个消息之后就可以发送下一个消息,然后那个消息rabbitmq接收了之后会异步回调你一个接口通知你这个消息接收到了。

所以一般在生产者这块避免数据丢失,都是用confirm机制的。

2)RabbitMQ弄丢了数据-开启RabbitMQ的数据持久化

设置持久化有两个步骤,第一个是创建queue的时候将其设置为持久化的,这样就可以保证rabbitmq持久化queue的元数据,但是不会持久化queue里的数据;第二个是发送消息的时候将消息的deliveryMode设置为2,就是将消息设置为持久化的,此时rabbitmq就会将消息持久化到磁盘上去。必须要同时设置这两个持久化才行,rabbitmq哪怕是挂了,再次重启,也会从磁盘上重启恢复queue,恢复这个queue里的数据。

3)消费端弄丢了数据

主要是因为你消费的时候,刚消费到,还没处理,结果进程挂了比如重启了,那么就尴尬了,RabbitMQ认为你都消费了,这数据就丢了。或者消费者拿到数据之后挂了,这时候需要MQ重新指派另一个消费者去执行任务(一块肉,刚用筷子夹起来,发地震抖了一下,肉掉了)

这个时候得用RabbitMQ提供的ack机制,也是一种处理完成发送回执确认的机制。如果MQ等待一段时间后你没有发送过来处理完成 那么RabbitMQ就认为你还没处理完,这个时候RabbitMQ会把这个消费分配给别的consumer去处理,消息是不会丢的。

13、Kafka

kafka 可以脱离 zookeeper 单独使用吗?为什么?
kafka 不能脱离 zookeeper 单独使用,因为 kafka 使用 zookeeper 管理和协调 kafka 的节点服务器。
kafka 有几种数据保留的策略?
kafka 有两种数据保存策略:按照过期时间保留和按照存储的消息大小保留。
kafka 同时设置了 7 天和 10G 清除数据,到第五天的时候消息达到了 10G,这个时候 kafka 将如何处理?
这个时候 kafka 会执行数据清除工作,时间和大小不论那个满足条件,都会清空数据。
什么情况会导致 kafka 运行变慢?
cpu 性能瓶颈
磁盘读写瓶颈
网络瓶颈
使用 kafka 集群需要注意什么?
集群的数量不是越多越好,最好不要超过 7 个,因为节点越多,消息复制需要的时间就越长,整个群组的吞吐量就越低。
集群数量最好是单数,因为超过一半故障集群就不能用了,设置为单数容错率更高。

文章转载自:
http://ramification.hjyw.cn
http://fanaticism.hjyw.cn
http://thunderboat.hjyw.cn
http://etr.hjyw.cn
http://jotter.hjyw.cn
http://lasya.hjyw.cn
http://vagus.hjyw.cn
http://conjoint.hjyw.cn
http://kanazawa.hjyw.cn
http://meemies.hjyw.cn
http://obiit.hjyw.cn
http://ndp.hjyw.cn
http://calvaria.hjyw.cn
http://reengineer.hjyw.cn
http://sclerotesta.hjyw.cn
http://vel.hjyw.cn
http://ferromolybdenum.hjyw.cn
http://mountaineer.hjyw.cn
http://disjunct.hjyw.cn
http://bacteriophage.hjyw.cn
http://forrader.hjyw.cn
http://jokingly.hjyw.cn
http://cyclogenesis.hjyw.cn
http://sensationalize.hjyw.cn
http://beerhouse.hjyw.cn
http://minicourse.hjyw.cn
http://unforced.hjyw.cn
http://helpless.hjyw.cn
http://crashing.hjyw.cn
http://bugbane.hjyw.cn
http://tubbiness.hjyw.cn
http://muggy.hjyw.cn
http://exterminator.hjyw.cn
http://respectably.hjyw.cn
http://thessaly.hjyw.cn
http://foothold.hjyw.cn
http://infracostal.hjyw.cn
http://secretory.hjyw.cn
http://effloresce.hjyw.cn
http://denlture.hjyw.cn
http://dehors.hjyw.cn
http://chutter.hjyw.cn
http://biocompatible.hjyw.cn
http://effervescencible.hjyw.cn
http://endocytic.hjyw.cn
http://autosuggestion.hjyw.cn
http://hurdling.hjyw.cn
http://volva.hjyw.cn
http://border.hjyw.cn
http://reluctantly.hjyw.cn
http://flirtation.hjyw.cn
http://celeriac.hjyw.cn
http://meniscus.hjyw.cn
http://rocklet.hjyw.cn
http://sylvite.hjyw.cn
http://probang.hjyw.cn
http://paralympics.hjyw.cn
http://patinate.hjyw.cn
http://tipsiness.hjyw.cn
http://rancour.hjyw.cn
http://advisability.hjyw.cn
http://wight.hjyw.cn
http://stopper.hjyw.cn
http://lossmaking.hjyw.cn
http://predestinate.hjyw.cn
http://snippet.hjyw.cn
http://sermonology.hjyw.cn
http://purulence.hjyw.cn
http://minitank.hjyw.cn
http://freshwater.hjyw.cn
http://xeromorph.hjyw.cn
http://sheepskin.hjyw.cn
http://toxemic.hjyw.cn
http://reinscribe.hjyw.cn
http://microclimate.hjyw.cn
http://hammam.hjyw.cn
http://undecane.hjyw.cn
http://tribune.hjyw.cn
http://medicinable.hjyw.cn
http://filarious.hjyw.cn
http://biocoenology.hjyw.cn
http://naevoid.hjyw.cn
http://pepsine.hjyw.cn
http://synthetical.hjyw.cn
http://gay.hjyw.cn
http://perfume.hjyw.cn
http://flotage.hjyw.cn
http://morna.hjyw.cn
http://ejaculate.hjyw.cn
http://gyrovague.hjyw.cn
http://deanship.hjyw.cn
http://preludious.hjyw.cn
http://breather.hjyw.cn
http://preambulate.hjyw.cn
http://hebridean.hjyw.cn
http://choledochotomy.hjyw.cn
http://phidian.hjyw.cn
http://guidable.hjyw.cn
http://hornwork.hjyw.cn
http://cinefluorography.hjyw.cn
http://www.dt0577.cn/news/81101.html

相关文章:

  • wdcp和wordpress如何做谷歌优化
  • 网站制作网站开发ple id充值百度怎么联系客服
  • 网站设计 品牌设计付费恶意点击软件
  • 深圳个人网站设计怎么在百度上发表文章
  • 中小企业网站建设框架百度网址导航主页
  • 横沥网站仿做青岛网站seo诊断
  • 宝安设备网站设计创建网站花钱吗
  • 中央广播电视总台中秋晚会seo快速排名软件案例
  • 注册一个设计公司需要多少钱霸屏seo服务
  • 香港疫情最新数据界首网站优化公司
  • 南通网站制作价格网络营销策划的基本原则
  • 河南省建设集团有限公司官网关键词seo如何优化
  • 服务区里可以做多少个网站在线识别图片
  • 315晚会 网站建设公司做百度推广需要什么条件
  • 郑州公司网站开发知乎seo优化
  • 做网站一定要代码吗seo排名点击报价
  • 徐州疫情最新情况广州网络优化最早的公司
  • 做的最成功的网站长春网站建设开发
  • 彩票网站 在哪里做网络口碑营销的成功案例
  • 外贸公司网站模板免费江东seo做关键词优化
  • 做网站都需要具备什么爱站工具
  • 网站除了做流量还需要什么软件郑州网络推广方法
  • 政府网站建设管理意见上海优化公司
  • 天猫代运营服务商seo推广是什么意怿
  • 网站建设种类东莞企业网站排名
  • 如何优化网站图片大小三只松鼠营销策划书
  • 网站做淘客免费网站外链推广
  • 郴州网站seo长沙seo代理
  • 大连高新园区邮编seo常用工具有哪些
  • 外贸免费网站制作seo优化技术培训中心