第一章: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 工具查看:
从消息队列中接收消息略微复杂些。其通过预先在消息队列中声明一个回调函数callback来完毕。当我们接收一条消息后,回调函数将会被pika库调用。回调函数函数体能够将对应的内容显示在屏幕上:
然后,我们须要通知rabbitmq特定的回调函数来接收来自“hello”消息队列中的消息:
在通知rabbitmq之前。我们也须要确保消息队列已经存在。
这在我们之前调用queue_declare函数后就已经完毕了该确认工作。
No_ack參数在后面会具体介绍。
最后我们将进入通过一个循环来等待接收数据并在须要时执行回调函数(即收到消息后):