第一章: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. Laravel5.1学习笔记5 请求

    HTTP 请求 #取得请求实例 #基本的请求信息 #PSR-7 请求 #取出输入数据 #旧的输入 #Cookies #文件 #取得请求实例(此部分文档5.1完全重写,注意) 要通过依赖注入获取当前HT ...

  2. Android第一次项目

    学习了一个月的Android,接触了人生中第一个安卓项目,对于一个小白来说,总结是很重要的学习方法,以下我把学到的东西总结以下: 1. 1>okhttp3用法解析(边贴代码边熟悉) public ...

  3. poj1101 the game 广搜

    题目大意: 类似于连连看,问从起点到终点最少需要几条线段. 规则: 1.允许出界. 2.空格的地方才能走. 分析: 题目做下来发现没有卡时间,所以主要还是靠思路.也就是说不用考虑离线算法.直接以每个起 ...

  4. java ---书写自己的名字

    public class hello { public static void main(String[] args) { // TODO 自动生成的方法存根 System.out.println(& ...

  5. selenium有多个窗口时操作某个窗口的内容

    这个页面点击html/css后会弹出一个新的窗口,此时要操作新的窗口的内容,使用switchTo 跳转代码 driver.get("https://www.imooc.com"); ...

  6. 闲着无聊时写的一个调用天气 API 的小 Demo

    分为两个部分--调用以及实现,并且由于不想折腾,直接使用了 Console 来调用. 通过firefox直接调用 Main 入口,调用以及输出 调用部分没什么好说的,主要是针对 dynamic 类型的 ...

  7. ui界面设计

    UI即User Interface(用户界面)的简称,指对软件的人机交互.操作逻辑.界面美观的整体设计.好的UI设计不仅是让软件变得有个性有品位,还要让软件的操作变得舒适简单.自由,充分体现软件的定位 ...

  8. windows server 2008如何显示后缀名

    任意打开一个文件----点击左上角有个[组织]---[文件夹和搜索选项]---[查看]----去掉勾[隐藏已知文件类型的扩展名]---确定即可

  9. mysql主主同步

    Mysql 主主同步方案 第一台机器主 [root@master ~]# vim /etc/my.cnf [mysqld] server-id=1 log-bin=mysql-binlog log-s ...

  10. JavaScript、Dom和jQuery

    var obj=document.getElementById('t1') obj.innerText obj.innerHTML 1.javascript 插入代码如下: <script ty ...