在声明交换器和队列时,有一个属性叫autoDelete,表示是否自动删除. 如果autoDelete=true,表示自动删除.此处我们要理解,自动删除的条件是什么? 这里的关键是,自动删除的条件是向后的. RabbitMQ的整个消息流是,生产端发布消息和routingKey,经由交换器,依据routingKey,到达指定队列.队列推送消息到已经订阅此消息的消费者.  再来解释"自动删除的条件是向后的"这句话. 对于exchange交换器,向前是生产端发布的消息和routingKey,这…
里面有几个常用的功能,以后值得借鉴. 如获取脚本目录,IP,获取shell返回值,发送邮件等.. 上午写完,中午测试,下午上线~~ #!/usr/bin/env python # -*- coding:utf-8 -*- import smtplib from email.mime.text import MIMEText import socket import fcntl import struct import sys import os #########################…
删除MSMQ中消息队列时出现 google之,发现也没有找到解决方法,自己在琢磨一下,一般出现这种问题的都是权限问题,因此查看了一下属性,果然如此 此消息队列是使用Windows服务创建的 解决办法:打开消息队列的属性,点击“安全”标签 点击“高级” ==>点击“所有者” 点击自己的用户 点击应用,添加 Everyone 权限 即可删除此队列…
​ 从RabbitMQ 3.6.0之后,有了 Lazy Queues 的概念-一个会尽早的将队列中的内容移动到磁盘的队列,并且只有当消费者需要的时候,才会将它们加载到内存中 ​ 惰性队列设计的一个主要的目的就是去支持非常长的队列(上亿级).队列可能会变的非常长因为各种各样的原因: 消费者离线/宕机/停机维护 大量的请求突然涌入,生产者正在超过消费者 消费速度低于正常情况 ​ 默认情况下,当消息发送到RabbitMQ时,会被存储在内存中,这样做的主要目的是为了消息能尽快的发送给消费者.即使是持久化…
在windows中的rabbitmq安装目录中的/sbin目录下: rabbitmqctl.bat stop_app rabbitmqctl.bat reset rabbitmqctl start_app…
上一篇博客我们介绍了RabbitMQ消息通信中的一些基本概念,这篇博客我们介绍 RabbitMQ 的五种工作模式,这也是实际使用RabbitMQ需要重点关注的. 这里是RabbitMQ 官网中的相关介绍:http://www.rabbitmq.com/getstarted.html 本篇博客源码下载地址:https://github.com/YSOcean/RabbitMQTest 1.简单队列 其实上篇文章末尾给出的代码就是简单队列. 一个生产者对应一个消费者!!! 生产者将消息发送到“hel…
知识储备: 交换机: ​ RabbitMQ中有4中交换机,分别是 (FANOUT)扇形交换机: 扇形交换机是最基本的交换机类型,它所能做的事情非常简单---广播消息.扇形交换机会把能接收到的消息全部发送给绑定在自己身上的队列.因为广播不需要"思考",所以扇形交换机处理消息的速度也是所有的交换机类型里面最快的. (DIRECT)直连交换机 直连交换机是一种带路由功能的交换机,一个队列会和一个交换机绑定,除此之外再绑定一个routing_key,当消息被发送的时候,需要指定一个bindin…
前言 前段时间在编写通用的消息通知服务时,由于需要实现类似通知失败时,需要延后几分钟再次进行发送,进行多次尝试后,进入定时发送机制.此机制,在原先对接银联支付时,银联的异步通知也是类似的,在第一次通知失败后,支付标准服务会重发,最多发送五次,每次的间隔时间为1.4.8.16分钟等.本文就简单讲解下使用RabbitMQ实现延时消息队列功能. 前言 一点知识 延时队列使用场景 RabbitMQ实现延时队列 存活时间(Time-To-Live 简称 TTL) 死信交换(Dead Letter Exch…
vhost本质上是一个mini版的RabbitMQ服务器,拥有自己的队列.绑定.交换器和权限控制: vhost通过在各个实例间提供逻辑上分离,允许你为不同应用程序安全保密地运行数据: vhost是AMQP概念的基础,必须在连接时进行指定,RabbitMQ包含了默认vhost:"/": 当在RabbitMQ中创建一个用户时,用户通常会被指派给至少一个vhost,并且只能访问被指派vhost内的队列.交换器和绑定,vhost之间是绝对隔离的. vhost可以理解为虚拟broker,即min…
AMQP协议的梳理和名词解析  建议先把上篇AMQP协议先看一遍,理解一下,由于用XMind绘图,电脑屏幕比较小,不能截取全部,如果想要全图和源代码,请下面留言....... 可以点击图片,打开到新的页面查看,文字会清晰一点..... 实例一:生产者-队列-消费者 P(Producer):生产者,意味着发送: Queue:队列,本质上是一个无限的缓冲区,可以储存尽可能多的信息: C(Consumer):消费者,等待并接收消息. 代码 简述:三部分,创建连接对象的公共帮助类库,一个发布者,一个消费…