你是否听说过或者使用过队列

你是否听说过或者使用过消息队列

你是否听说过或者使用过RabbitMQ

提到这几个词,用过的人,也许觉得很简单,没用过的人,也许觉得很复杂,至少在我没使用消息队列之前,听别人提到消息队列,都感觉很复杂,很高深。

好了,言归正传,本篇博客我们就讲解下什么是消息队列,RabbitMQ环境的安装配置,最后通过一个Hello World示例了解下RabbitMQ的使用方法。

1. 基本概念讲解

1.1 队列(Queue)

队列是常用的数据结构之一,是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作。

进行插入操作的端称为队尾,进行删除操作的端称为对头。

在Java中,java.util包下已经有队列的相关实现,我们可以直接使用。

1.2 消息队列(Message Queue)

消息是计算机/应用间传送的数据单位,可以非常简单,例如只包含文本字符串,也可以很复杂,可能包含嵌入对象。

消息队列是在消息的传输过程中保存消息的容器。

消息传输时,先发送到队列,队列的主要目的是提供路由并保证消息的传递,如果发送消息时接收者不可用,消息队列会保留消息,直到可以成功的传递它。

可以把消息队列理解成快递公司,你需要寄一个物件(消息)给你的朋友,快递公司收到物件会保证物件送到你的朋友手中,可能存在多次寄送才送达成功的情况,比如第一次送过去,你朋友不在家。

也许有人好奇,为什么我们不直接使用JDK自带的队列,而是要使用消息队列呢?

这是因为JDK自带的队列都存储在内存中,一但应用或者服务器挂了,消息就丢失了,使用消息队列可以避免消息丢失问题(注意不是100%不丢失),就像快递公司会保证你的物件寄到你的朋友手中,但肯定有丢件的几率。

1.3 RabbitMQ

RabbitMQ是用Erlang语言开发的基于高级消息队列协议(AMQP)的消息队列中间件。

因为它开源,而且版本更新快,所以在国内互联网公司被广泛使用。

其它使用的消息中间件还有ActiveMQ,RocketMQ,Kafka等,有兴趣的同学可以自行研究。

还有2个专业术语要了解下:

生产者:发送消息的应用程序被称为生产者。

消费者:接收消息的应用程序被称为消费者。

2. RabbitMQ安装及配置

了解完基本概念,让我们在本机上安装下RabbitMQ,因为它是基于Erlang语言开发的,所以我们要先安装Erlang。

2.1 Erlang安装及配置

Erlang下载地址:http://www.erlang.org/downloads

因为我的电脑是Windows 64位系统,所以我下载的是64位的,系统是32位的同学注意下版本。

安装过程比较简单,以下为部分截图:

安装完成后,需要新建个环境变量(打开方式:计算机--右键--属性--高级系统设置--高级--环境变量):

ERLANG_HOME E:\Program Files\erl10.4(修改为你的安装路径)

2.2 RabbitMQ安装及配置

RabbitMQ下载地址:https://www.rabbitmq.com/install-windows.html

安装过程也比较简单,以下为部分截图:

安装完成后,在cmd窗口中执行以下命令激活RabbitMQ Manage Plugin

  1. "E:\Program Files\RabbitMQ Server\rabbitmq_server-3.7.15\sbin\rabbitmq-plugins.bat" enable rabbitmq_management

然后执行命令重启RabbitMQ服务:

  1. net stop RabbitMQ && net start RabbitMQ

如果你的cmd窗口不是以管理员身份打开的,会出现如下报错信息

解决方法也很简单,以管理员身份打开cmd窗口执行命令即可

关于这一步,可以不使用命令重启RabbitMQ服务,而是打开Windows的服务列表,找到RabbitMQ服务,重启即可。

到这一步,RabbitMQ的安装就算完成了,其中有几个默认值,我们要知晓下:

  • 默认的端口号:5672
  • 默认的用户是guest guest
  • 管理后台的默认端口号:15672

浏览器输入http://localhost:15672/,我们可以看到RabbitMQ的管理后台,然后使用默认的guest账号登录,在这个后台,可以完成新建用户,配置用户角色,新建队列等操作,当然,如果有的同学比较喜欢命令行操作,也都有相对应的命令来完成操作,关于这些内容,后续单独再写博客讲解。

3. Hello World示例

既然RabbitMQ环境安装好了,那么我们通过1个简单的示例来看下效果。

首先在pom文件中,添加依赖:

  1. <dependency>
  2. <groupId>com.rabbitmq</groupId>
  3. <artifactId>amqp-client</artifactId>
  4. <version>5.7.0</version>
  5. </dependency>

然后新建一个生产者类(Producer),用来新建一个队列'hello',然后往队列里发送消息‘Hello World’:

  1. package com.zwwhnly.springbootaction.rabbitmq.helloworld;
  2. import com.rabbitmq.client.Channel;
  3. import com.rabbitmq.client.Connection;
  4. import com.rabbitmq.client.ConnectionFactory;
  5. import java.io.IOException;
  6. import java.util.concurrent.TimeoutException;
  7. public class Producer {
  8. private final static String QUEUE_NAME = "hello";
  9. public static void main(String[] args) throws IOException, TimeoutException {
  10. // 创建连接
  11. ConnectionFactory factory = new ConnectionFactory();
  12. // 设置 RabbitMQ 的主机名
  13. factory.setHost("localhost");
  14. // 创建一个连接
  15. Connection connection = factory.newConnection();
  16. // 创建一个通道
  17. Channel channel = connection.createChannel();
  18. // 指定一个队列,不存在的话自动创建
  19. channel.queueDeclare(QUEUE_NAME, false, false, false, null);
  20. // 发送消息
  21. String message = "Hello World!";
  22. channel.basicPublish("", QUEUE_NAME, null, message.getBytes());
  23. System.out.println(" [x] Sent '" + message + "'");
  24. // 关闭频道和连接
  25. channel.close();
  26. connection.close();
  27. }
  28. }

运行代码,在RabbitMQ管理后台,会看到队列新建成功,并且有1个消息待消费:

最后我们新建一个消费者类(Consumer),用来消费这个消息:

  1. package com.zwwhnly.springbootaction.rabbitmq.helloworld;
  2. import com.rabbitmq.client.*;
  3. import java.io.IOException;
  4. import java.util.concurrent.TimeoutException;
  5. public class Consumer {
  6. private final static String QUEUE_NAME = "hello";
  7. public static void main(String[] args) throws IOException, TimeoutException {
  8. // 创建连接
  9. ConnectionFactory factory = new ConnectionFactory();
  10. // 设置 RabbitMQ 的主机名
  11. factory.setHost("localhost");
  12. // 创建一个连接
  13. Connection connection = factory.newConnection();
  14. // 创建一个通道
  15. Channel channel = connection.createChannel();
  16. // 指定一个队列
  17. channel.queueDeclare(QUEUE_NAME, false, false, false, null);
  18. // 创建队列消费者
  19. com.rabbitmq.client.Consumer consumer = new DefaultConsumer(channel) {
  20. @Override
  21. public void handleDelivery(String consumerTag, Envelope envelope,
  22. AMQP.BasicProperties properties, byte[] body) throws IOException {
  23. String message = new String(body, "UTF-8");
  24. System.out.println("Received Message '" + message + "'");
  25. }
  26. };
  27. channel.basicConsume(QUEUE_NAME, true, consumer);
  28. }
  29. }

运行代码,我们会发现控制台输出:

Received Message 'Hello World!'

此时再看下RabbitMQ管理后台,会发现队列'hello'待消费的消息为0:

是不是觉得挺简单的呢,赶紧在本机安装试试吧!

4. 源码及参考

源码地址:https://github.com/zwwhnly/springboot-action.git,欢迎下载。

windows下 安装 rabbitMQ 及操作常用命令

【译】RabbitMQ 实战教程(一) Hello World!

原创不易,如果觉得文章能学到东西的话,欢迎点个赞、评个论、关个注,这是我坚持写作的最大动力。

如果有兴趣,欢迎添加我的微信:zwwhnly,等你来聊技术、职场、工作等话题(PS:我是一名奋斗在上海的程序员)。

RabbitMQ使用教程(一)RabbitMQ环境安装配置及Hello World示例的更多相关文章

  1. RabbitMQ教程(一)——安装配置

    RabbitMQ教程(一)——安装配置 一.前言 由于最近在学习RabbitMQ消息队列,但是鉴于网上对于官网介绍的教程比较少或者由于时间长长期未更新,因此决定将对官网的RabbitMQ入门教程进行翻 ...

  2. QT开发环境安装配置教程

    QT开发环境安装配置教程 分类: QT2012-11-29 23:31 35366人阅读 评论(12) 收藏 举报 Linux版的直接在ubutnu软件中心输入QT,安装响应的Designer,Cre ...

  3. [转]Tomcat9.0安装教程 Tomcat9.0环境变量配置教程

    [转]Tomcat9.0安装教程 Tomcat9.0环境变量配置教程 [转]超详细MySQL安装及基本使用教程

  4. Meteor环境安装配置

    在本教程中,我们将展示如何在windows操作系统安装Meteor .在我们开始学习使用Meteor 之前,我们将需要NodeJS.如果你还没有安装它,则可以点击下表中的链接. 必须条件 Meteor ...

  5. Linux下xampp集成环境安装配置方法 、部署bugfree及部署禅道

    XAMPP(Apache+MySQL+PHP+PERL)是一个功能强大的建站集成软件包.XAMPP 是一个易于安装且包含 MySQL.PHP 和 Perl 的 Apache 发行版.XAMPP 的确非 ...

  6. Sencha Toucha 2 —1.环境安装配置、在线打包、离线打包

    环境安装配置        1. 下载 1.1     Sencha Touch 下载 http://cdn.sencha.com/touch/sencha-touch-2.2.1-gpl.zip 1 ...

  7. [转载]SharePoint 2013测试环境安装配置指南

    软件版本 Windows Server 2012 标准版 SQL Server 2012 标准版 SharePoint Server 2013 企业版 Office Web Apps 2013 备注: ...

  8. Windows7 x64 跨平台开发环境安装配置

    ======================================================================= Windows7 x64 跨平台开发环境安装配置 201 ...

  9. 一个电脑的重装到java开发环境安装配置的全过程

    刚拿到一台别人用过的电脑.看着c盘爆满,而且用了还是windows7操作系统,强迫症发作马上就准备重装系统. 之前换固态使用wepe制作U盘启动盘装系统的步骤和过程全部忘记的,贼尴尬. 同事都看不过眼 ...

随机推荐

  1. hive通过spark导入hbase

    发现采用shcjar的话,总是执行到某个点就停止了 于是我打算尝试一下直接说哦用org.apache.hadoop.hbase.spark这个datasource看看 确实不行,即使没有createt ...

  2. SimpliciTI简介

    SimpliciTI简介 SimpliciTI是TI开发的一份专门针对其CCxxxx系列无线通信芯片的网络协议.按照其官方说法SimpliciTI是一个基于连接的点对点通讯协议.它支持两种网络拓扑结构 ...

  3. UnicodeDecodeError: 'ascii' codec can't decode byte 0xe6 in position 0: ordinal not in range(128)

    2017-03-16 11:23:29.601 1238 ERROR nova.compute.manager [instance: 3f195047-250a-4eb5-8da0-63bea6e26 ...

  4. maven 依赖范围

  5. 原生JS中unshift与shift

    shift() 方法:shift() 方法用于把数组的第一个元素从其中删除,并返回第一个元素的值:用法:arrayObject.shift()如果数组是空的,那么 shift() 方法将不进行任何操作 ...

  6. wpf窗口禁止最大化但允许调整大小

    wpf中窗口禁止最大化可以通过属性ResizeMode来设置,但是ResizeMode有一个问题就是如果ResizeMode设置为NoResize的话,是可以禁止最大化的,但是这样同时也就不能拖动调整 ...

  7. poj3535 A+B (大数加法)

    A+B Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 811   Accepted: 371 Description The ...

  8. UVa 11100 The Trip, 2007 (题意+贪心)

    题意:有n个包,其中小包可以装到大的包里,包的大小用数字进行表示,求最小的装包数量. 析:这个题的题意不太好理解,主要是有一句话难懂,意思是让每个最大包里的小包数量的最大值尽量小,所以我们就不能随便输 ...

  9. 由一次动态改变font-size的大小引申的一系列困惑补录

    以下结论如有错误,欢迎指正 在切入正题之前,先了解下window 和document这两个大对象 我们熟知 JavaScript的组成如下图所示: window对象和document对象分别属于哪个分 ...

  10. Python:asyncio模块学习

    python asyncio 网络模型有很多中,为了实现高并发也有很多方案,多线程,多进程.无论多线程和多进程,IO的调度更多取决于系统,而协程的方式,调度来自用户,用户可以在函数中yield一个状态 ...