如果处理发消息时服务器挂掉,rabbit服务器挂掉以后,保证队列消息还存在(tp框架)(第三篇)...

上接 第二篇 : http://www.cnblogs.com/spicy/p/7921870.html

第二篇解决了 如果其中一个worker挂掉了啦,如何保证消息不丢掉,并重新分发给其他worker

现在要解决: 如果rabbitmq服务器挂掉了的话,如果保证队列里面的消息还在

方案:

第一步 : 必须保证publisher 和 consumer 下面都保持一致,第三个参数都是true

0cc9567d85d747b61b0efd367ffcf6a2.png

第二步: 新建消息的时候 增加一个选项,让消息传递模式为persisitent

af07be8cbe167f4310049d7dc59190b7.png

但是官方也说了:这样也不能完全保证消息不能丢失

cbe806d8d9186c8844ed9f13717f2ac7.png

实验: 发布10条消息:然后重启rabbitmq, 然后打开worker 发现消息在存在 并且分发给了worker去处理掉了

实验问题一: 如果消息正在消费的时候去关闭rabbitmq服务器,这个时候再重启的时候发现 所有的消息都没有了,原因就是开启了auto_delete

导致,只要一开起以后,服务器就会把消息一次性分发出去,然后删除掉

解决方案:在publisher 和 worker 二边都关闭掉auto_delete

71d7f2a5c65f0d16a19bddc4337d5f0f.png

实验问题二: 如果开启多个worker 会发现服务器会平均分发比如(1,3,5,7,9给worker1,  2 ,4,6,8,10 给worker2),而不是根据每个worker的busy程度来分发消息

解决方案: 在消费前面加上的一个配置

9fb52ac09c451645fb3726e9251057fd.png

RabbitMQ使用教程(五)如何保证队列里的消息99.99%被消费?

1. 前情回顾 RabbitMQ使用教程(一)RabbitMQ环境安装配置及Hello World示例 RabbitMQ使用教程(二)RabbitMQ用户管理,角色管理及权限设置 RabbitMQ使用 ...

ActiveMQ监听消息并进行转发,监听不同的mq服务器和不同的队列

工作中刚接触mq消息业务,其实也就是监听一下别的项目发送的消息然后进行对应的转发,但是监听的mq会有多个,而且转发的地址也可能有多个,这里就使用spring集成的方式!记录一下实现方式: 监听多个mq ...

rabbitmq实现一台服务器同时给所有的consumer发送消息(tp框架)(第四篇)

之前的学习了把消息直接publish到queue里面,然后consume掉, 真实的情况,我们会把消息先发送到exchange里面,由它来处理,是发给某一个队列,还是发给某些队列,还是丢弃掉? exc ...

利用rabbit_mq队列消息实现对一组主机进行命令下发

目的: 利用rabbit_mq队列消息实现对一组主机进行命令下发 server: #!/usr/bin/env python3.5 # -*- coding:utf8 -*- import os,sy ...

rabbitmq实现一台服务器同时给指定部分的consumer发送消息(tp框架)(第六篇)

previous article:  http://www.cnblogs.com/spicy/p/7989717.html 上一篇学习了,发送消息的时候用direct类型的exchange,绑定不同 ...

Java并发编程原理与实战三十六:阻塞队列&消息队列

一.阻塞队列 1.阻塞队列BlockingQueue ---->可以理解成生产者消费者的模式---->消费者要等待到生产者生产出来产品.---->而非阻塞队列ConcurrentLi ...

IM消息送达保证机制实现(二):保证离线消息的可靠投递

1.前言 本文的上篇中,我们讨论了在线实时消息的投递可以通过应用层的确认.发送方的超时重传.接收方的去重等手段来保证业务层面消 ...

【转】Skynet之消息队列 - 消息的存储与分发

Skynet之消息队列 - 消息的存储与分发 http://www.outsky.org/code/skynet-message-queue.html Sep 8, 2014 按我的理解,消息队列是S ...

【python】-- RabbitMQ 队列消息持久化、消息公平分发

RabbitMQ 队列消息持久化 假如消息队列test里面还有消息等待消费者(consumers)去接收,但是这个时候服务器端宕机了,这个时候消息是否还在? 1.队列消息非持久化 服务端(produc ...

随机推荐

【.NET深呼吸】动态类型(扩充篇)

前面两文中,老周已向大家介绍了关于动态类型对象的两种级别的使用方案,本篇呢,老周再讲一个自定义动态类型的例子. 前面给大家演示的例子中,动态类型中包装的是字典类型来存储数据的,这一次咱们换一种风味,老 ...

JS-数值篇

数值(一) 一.数值 163——整型 3.14——符点数 2.5e11——科学计数法 0xfa1b——16进制 二.运算 1.Math.abs(x)——绝对值 举例:Math.abs(5) //5 M ...

ssh公私钥登录方式设置

在Linux中ssh登录远程主机的时候能够进行公私钥的认证方式. ①环境说明:两台Linux主机,host1:192.168.5.1,host2:192.168.5.10. 如今在host1上面设置然 ...

D3D 练习小框架

自己练习D3D 程序搭的小框架,记录在这里,将来看到好回顾自己独自摸索的苦逼样子. #pragma once #pragma comment(lib,"d3d9.lib") #pr ...

iOS开发——沙箱

iphone沙箱模型的有三个文件夹,documents,tmp,Library.有时开发时要求我们保存一些数据在本地,这就用到了. 1.Documents 目录:您应该将所有de应用程序数据文件写入到 ...

Struts2中的值栈

一 什么是值栈 值栈: struts2中提供的一种类似于域对象的工具, 用于struts2中的存值和取值. 每次访问Action的时候, 都会创建一个action对象, 而每个action对象中都存在 ...

javascript面向对象理解的补充

js inherit demo
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值