第一章:Rabbitmq简单介绍

简单介绍:

Rabbitmq是一个消息中间件。主要用于消息的转发和接收。假设把rabbitmq比作邮局:仅仅要你将信件投递到邮箱,你就能够确信邮递员将能够把你的信件递送到目的地。

Rabbitmq的功能就相当于邮箱、邮局、邮递员的所代表的功能。

邮局递送的是纸质信件,Rabbitmq所不同之处就是其功能是接收、存储和转发的是二进制大对象数据。即Messages。

Rabbitmq相关术语:

(1)      Producing(生产):生产相当于消息发送(sending)。我们把发送消息的程序成为一个生产者(producer)。用例如以下图形表示:

(2)      queue(队列):Rabbitmq的队列相当于上文比喻的邮箱。它位于rabbitmq内部。虽然消息在应用程序和Rabbitmq间传递。但其仅仅能保存在队列中。

假设未对队列设定限制条件。队列是可以保存你想保存的随意信息。

其实,队列本质上是一个无容量限制的buffer。一些生产者向队列中发送消息后。消息消费者就行从队列中获取消息进行处理。

队列可以用例如以下图表示:

(3)      Consuming(消费):消费相当于消息接收(receiving)。

通常。消息消费者是一个等待接收消息队列中消息的应用程序。消息消费者用例如以下图表:

通常,消息生产者、消息消费者和消息中间件通常不在同一台机器上。

一个简单的rabbitmqhelloworld程序

helloword程序主要简单实现消息的发送,接收并打印到屏幕上。实现该功能须要写两个简单程序:一个用于发送消息。一个用于接收消息并打印消息到屏幕上。

例如以下图所看到的:

消息生产者发送消息到名为“hello”的消息队列中,消息消费者从该队列中接收消息。

TIPS:

rabbitmq库

Rabitmq实现了AMQP协议。使用rabbit须要导入一些库,这些库也须要像 rabbit一样遵循AMQP协议。

每一种语言都会有多种库可供选择。

Python语言的实现库主要有:

->Py-amqplib

->txAMQP

->pika

本文档主要使用pika库。

安装pythonpika包: $ sudo pip install pika==0.9.8

安装pika 依赖 pip 和git-core包。

在安装pika前须要安装这些依赖包。

Ubuntu安装: sudo apt-get install python-pip git-core

Debian安装: apt-get install python-setuptools git-core

sudo easy-install pip

window安装: easy_install pip

pip install pika==0.9.8

消息发送:

本文档通过send.py来完毕消息的发送。首先须要建立一个到RabbitMQ 服务的连 接。

上面已经建立了一个到本机中间件的连接。

假设中间件服务执行在远程的机器上,仅仅需改动连接參数为远程主机的 ip地址就可以。

建立完连接后。还须要确保消息接收队列已存在。假设发送一条消息到一个不存在的位置,rabbitmq 将对发送的消息进行垃圾回收。比如,创建一个名为“hello”的消息队列来接收消息,创建步骤例如以下:

创建完后,就能够開始发送消息了。本例中将发送一条包括一个“hello”字符串的消息到名为“hello”的消息队列中。

在rabbitmq中。消息永远都无法直接发送到消息队列中。总是须要通过exchange,然后发送到消息队列。Exchange的具体介绍将在后面给出。这里仅仅需了解怎样使用一个默认的名为空字符串的exchange,这个特定的exchange可以指定我们的消息应该发到哪个消息队列中。消息队列名须要在routing_key參数中指定:

在退出程序前,我们须要确保网络缓存被刷清,而且消息被发送到rabbitmq。

然后我们才关闭连接。

TIPS: 消费发送过程无法完毕

假设你第一次使用rabbitmq。当看到消息无法发送且不知道为何出错时。或许你须要检測你的消息中间件启动时是否有足够的磁盘空间(默认须要至少1G空间)。空间太少可能导致消息中间件拒绝接收消息。检測中间日志发现确实是空间少后,能够降低磁盘空间限制。配置文件文档中具体说明了怎样通过设置disk_free_limit来降低磁盘空间的限制。

消息接收:

本文档通过receive.py来完毕消息队列中消息的接收并输出显示出来。相同,首先须要连接到rabbitmq server。连接方法如上。

然后确保消息队列已经存在。

通过queue_declare 方法能够创建消息队列。他们能够多次运行该方法。

但仅仅有第一次运行时才会创建。

或许你会问为什么我们在前面运行过该方法,为什么还需再次调用该方法呢?假设你能确定以及运行过该方法,那么就能够不用反复运行。但假设我们不确定是否运行过该方法时。

在多个程序中反复调用该方法来确保消息队列已经存在也不失为一种好的解决方法。

TIPS:想要查看哪些rabbitMQ已经存在和消息队列中有多少消息。能够通过rabbitmqctl 工具查看:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvZ3l1bmxpbmc=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

从消息队列中接收消息略微复杂些。其通过预先在消息队列中声明一个回调函数callback来完毕。当我们接收一条消息后,回调函数将会被pika库调用。回调函数函数体能够将对应的内容显示在屏幕上:

然后,我们须要通知rabbitmq特定的回调函数来接收来自“hello”消息队列中的消息:

在通知rabbitmq之前。我们也须要确保消息队列已经存在。

这在我们之前调用queue_declare函数后就已经完毕了该确认工作。

No_ack參数在后面会具体介绍。

最后我们将进入通过一个循环来等待接收数据并在须要时执行回调函数(即收到消息后):

rabbitmq 入门基础(一)的更多相关文章

  1. RabbitMQ 入门系列:2、基础含义理解:链接、通道、队列、交换机

    系列目录 RabbitMQ 入门系列:1.MQ的应用场景的选择与RabbitMQ安装. RabbitMQ 入门系列:2.基础含义:链接.通道.队列.交换机. RabbitMQ 入门系列:3.基础含义: ...

  2. RabbitMQ 入门系列:3、基础含义:持久化、排它性、自动删除、强制性、路由键。

    系列目录 RabbitMQ 入门系列:1.MQ的应用场景的选择与RabbitMQ安装. RabbitMQ 入门系列:2.基础含义:链接.通道.队列.交换机. RabbitMQ 入门系列:3.基础含义: ...

  3. RabbitMQ 入门系列:3、基础编码:官方SDK的引用、链接创建、单例改造、发送消息、接收消息。

    系列目录 RabbitMQ 入门系列:1.MQ的应用场景的选择与RabbitMQ安装. RabbitMQ 入门系列:2.基础含义:链接.通道.队列.交换机. RabbitMQ 入门系列:3.基础含义: ...

  4. RabbitMQ 入门系列:5、基础编码:交换机的进阶介绍及编码方式。

    系列目录 RabbitMQ 入门系列:1.MQ的应用场景的选择与RabbitMQ安装. RabbitMQ 入门系列:2.基础含义:链接.通道.队列.交换机. RabbitMQ 入门系列:3.基础含义: ...

  5. RabbitMQ入门与使用篇

    介绍 RabbitMQ是一个由erlang开发的基于AMQP(Advanced Message Queue)协议的开源实现.用于在分布式系统中存储转发消息,在易用性.扩展性.高可用性等方面都非常的优秀 ...

  6. [转]RabbitMQ入门教程(概念,应用场景,安装,使用)

    原文地址:https://www.jianshu.com/p/dae5bbed39b1 RabbitMQ 简介 RabbitMQ是一个在AMQP(Advanced Message Queuing Pr ...

  7. RabbitMQ 入门指南——安装

    RabbitMQ好文 Rabbitmq Java Client Api详解 tohxyblog-博客园-rabbitMQ教程系列 robertohuang-CSDN-rabbitMQ教程系列 Rabb ...

  8. RabbitMQ入门:总结

    随着上一篇博文的发布,RabbitMQ的基础内容我也学习完了,RabbitMQ入门系列的博客跟着收官了,以后有机会的话再写一些在实战中的应用分享,多谢大家一直以来的支持和认可. RabbitMQ入门系 ...

  9. .NET 环境中使用RabbitMQ RabbitMQ与Redis队列对比 RabbitMQ入门与使用篇

    .NET 环境中使用RabbitMQ   在企业应用系统领域,会面对不同系统之间的通信.集成与整合,尤其当面临异构系统时,这种分布式的调用与通信变得越发重要.其次,系统中一般会有很多对实时性要求不高的 ...

随机推荐

  1. backface-visibility当元素不面向屏幕时是否可见

    html代码 <h1>div1可见</h1> <div class="div1">div---1</div> <h1>d ...

  2. android黑科技系列——Wireshark和Fiddler分析Android中的TLS协议包数据(附带案例样本)

    一.前言 在之前一篇文章已经介绍了一款网络访问软件的破解教程,当时采用的突破口是应用程序本身的一个漏洞,就是没有关闭日志信息,我们通过抓取日志获取到关键信息来找到突破口进行破解的.那篇文章也说到了,如 ...

  3. Android开放百度地图集成

    1.创建应用 获取AK (我理解为Application key)  通过百度账号登录百度地图开放平台,进入API控制台 http://lbsyun.baidu.com/apiconsole/key ...

  4. 用DIV遮罩解决checkbox勾选无效的问题

    在前端开发的过程中,遇到一种情况,需要勾选,为了用户的操作便捷就将click事件放到了DIV上.(其中使用了knockout.js) 代码大概如下: <div id="one" ...

  5. 09--c++ 类的继承与派生

    c++ 类的继承与派生   一.基本概念 1.类的继承,是新的类从已有类那里得到已有的特性.或从已有类产生新类的过程就是类的派生.原有的类称为基类或父类,产生的新类称为派生类或子类.   2.派生类的 ...

  6. Dispatch Queues and Thread Safety

    Dispatch Queues and Thread Safety It might seem odd to talk about thread safety in the context of di ...

  7. NSURLProtectionSpace 证书认证的上下文

    个NSURLProtectionSpace提供如下信息: //401的认证方式的realm字段的值 (NSString*)realm; //401的认证方式,指定是否密码发送安全. -(BOOL)re ...

  8. 02 java学习安装jdk及其环境配置

    SUN公司1995年正式推出的一款语言 其实之前,Sun公司1991年,James Gosling等人就开始开发Oak语言,希望用于控制嵌入有效电视交换盒,1994年更名为Java,之前来自 与jav ...

  9. servlet 中文编码设置

    Tomcat服务器默认采用的ISO8859-1编码 产生的原因: 不同数据来源的编(解)码格式不同: 数据来源 默认编码格式 浏览器页面 GBK(可在浏览器页面右键切换) request(get) I ...

  10. mysql 基础教程

    创建数据库: CREATE DATABASE --DATABASE 或者 SCHEMA数据库集合 IF NOT EXISTS db_name CHARACTER SET utf8 COLLATE ut ...