热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

RabbitMQ之介绍

 本文翻译自RabbitMQ官网。1、RabbitMQ的介绍     使用消息队列的一个主要的目的是解决数据消费速度和生产速度不一致的问题。     RabbitMQ是众多消息代理

 本文翻译自RabbitMQ官网。

1、RabbitMQ的介绍

         使用消息队列的一个主要的目的是解决数据消费速度和生产速度不一致的问题。

         Rabbit MQ是众多消息代理中的一种。本质上,它负责从生产者接收到消息,然后将消息发送给消费者。在这个过程中,它可以根据你的选择对消息传递进行路由、缓存消息或者是持久化消息。先来看一些术语:

(1)生产者即为发送者,发送消息的程序即为生产者,这里简称为P;


RabbitMQ之介绍

 

(2)队列:队列驻存在RabbitMQ中,消息可以在RabbitMq和应用之间流动,但最终消息是存储在队列中的。本质上,队列是一个有无限容量的buffer,可以存储尽可能多的消息,生产者可以将消息发送到一个队列,消费者也可以从一个队列中取消息。这里称队列为queue_name;


RabbitMQ之介绍

(3)消费者即为接收者,一般是等待着接收消息的应用。这里简称为C;


RabbitMQ之介绍

2、安装与配置

下载erlang  OTP 18.3 Windows 64-bit Binary File:https://www.erlang.org/downlowds

下载rabbitmq_server-3.6.1  :https://www.rabbitmq.com/download.html

启动server,如下:

 
RabbitMQ之介绍
 在maven中配置需要依赖的RabbitMQ客户端:

RabbitMQ之介绍

然后就可以开发RabbitMQ的demo了。

3、一个简单的demo

这个demo实现的功能很简单:

(1)有一个生产者,向消息队列中发送消息,消息为:“hello rabbit”;

(2)有一个消息队列,队列名称为:“hello”;

(3)有一个消费者,从消息队列中取消息,并打印出具体消息,如图所示。


RabbitMQ之介绍

实现:

(1)生产者:

首先创建连接工厂(ConnectionFactory),这里使用spring框架自动注入,如下所示:


RabbitMQ之介绍
 
RabbitMQ之介绍
 这里还添加了几个属性。

然后创建连接(Connection):

RabbitMQ之介绍
 然后创建通道(Channel):

RabbitMQ之介绍
 创建消息队列(Queue):

RabbitMQ之介绍
 其中:

queue -- 队列的名称

durable -- 队列的持久属性,在RabbitMQ重启后队列会不会丢失

exclusive -- 队列的排他属性,如果为true,则为创建该队列的消费者私有

autoDelete -- 队列的自动删除属性,在消费者断开连接的时候,队列是否会删除

然后生产者就可以发布消息了:

RabbitMQ之介绍
 

(2)消费者:

消费者的前期配置基本与生产者相同,注意队列的名称和属性要一致。

RabbitMQ之介绍
 注意有一个onBussiness方法,这就是在接收到消息之后,要做的处理工作。

RabbitMQ之介绍
(3)结果

先运行生产者,后运行消费者,消费端结果如下:

RabbitMQ之介绍
 消费成功。


推荐阅读
  • 本文介绍了Windows操作系统的版本及其特点,包括Windows 7系统的6个版本:Starter、Home Basic、Home Premium、Professional、Enterprise、Ultimate。Windows操作系统是微软公司研发的一套操作系统,具有人机操作性优异、支持的应用软件较多、对硬件支持良好等优点。Windows 7 Starter是功能最少的版本,缺乏Aero特效功能,没有64位支持,最初设计不能同时运行三个以上应用程序。 ... [详细]
  • 本文讨论了微软的STL容器类是否线程安全。根据MSDN的回答,STL容器类包括vector、deque、list、queue、stack、priority_queue、valarray、map、hash_map、multimap、hash_multimap、set、hash_set、multiset、hash_multiset、basic_string和bitset。对于单个对象来说,多个线程同时读取是安全的。但如果一个线程正在写入一个对象,那么所有的读写操作都需要进行同步。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了在Windows环境下如何配置php+apache环境,包括下载php7和apache2.4、安装vc2015运行时环境、启动php7和apache2.4等步骤。希望对需要搭建php7环境的读者有一定的参考价值。摘要长度为169字。 ... [详细]
  • 本文介绍了在mac环境下使用nginx配置nodejs代理服务器的步骤,包括安装nginx、创建目录和文件、配置代理的域名和日志记录等。 ... [详细]
  • 在springmvc框架中,前台ajax调用方法,对图片批量下载,如何弹出提示保存位置选框?Controller方法 ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
  • 背景应用安全领域,各类攻击长久以来都危害着互联网上的应用,在web应用安全风险中,各类注入、跨站等攻击仍然占据着较前的位置。WAF(Web应用防火墙)正是为防御和阻断这类攻击而存在 ... [详细]
  • Spring框架《一》简介
    Spring框架《一》1.Spring概述1.1简介1.2Spring模板二、IOC容器和Bean1.IOC和DI简介2.三种通过类型获取bean3.给bean的属性赋值3.1依赖 ... [详细]
  • 开发笔记:spring boot项目打成war包部署到服务器的步骤与注意事项
    本文介绍了将spring boot项目打成war包并部署到服务器的步骤与注意事项。通过本文的学习,读者可以了解到如何将spring boot项目打包成war包,并成功地部署到服务器上。 ... [详细]
  • 微软评估和规划(MAP)的工具包介绍及应用实验手册
    本文介绍了微软评估和规划(MAP)的工具包,该工具包是一个无代理工具,旨在简化和精简通过网络范围内的自动发现和评估IT基础设施在多个方案规划进程。工具包支持库存和使用用于SQL Server和Windows Server迁移评估,以及评估服务器的信息最广泛使用微软的技术。此外,工具包还提供了服务器虚拟化方案,以帮助识别未被充分利用的资源和硬件需要成功巩固服务器使用微软的Hyper - V技术规格。 ... [详细]
  • 本文介绍了SPOJ2829题目的解法及优化方法。题目要求找出满足一定条件的数列,并对结果取模。文章详细解释了解题思路和算法实现,并提出了使用FMT优化的方法。最后,对于第三个限制条件,作者给出了处理方法。文章最后给出了代码实现。 ... [详细]
  • linux进阶50——无锁CAS
    1.概念比较并交换(compareandswap,CAS),是原⼦操作的⼀种,可⽤于在多线程编程中实现不被打断的数据交换操作࿰ ... [详细]
  • 第七课主要内容:多进程多线程FIFO,LIFO,优先队列线程局部变量进程与线程的选择线程池异步IO概念及twisted案例股票数据抓取 ... [详细]
author-avatar
伴生约定_879
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有