前言

吃多了拉就是队列,吃饱了吐就是栈

  • 使用场景

    • 对操作的实时性要求不高,而需要执行的任务极为耗时;(发送短信,邮件提醒,更新文章阅读计数,记录用户操作日志)
    • 存在异构系统间的整合;

安装

  • 下载 Erlang

    • 安装完确定ERLANG_HOME环境变量是否添加,否则:Setx ERLANG_HOME “D:\Program Files\erl8.2″
  • 下载安装包

    • 安装完通过rabbitmqctl status确定rabbitmq状态
  • 管理服务

    • 默认安装成功会自动启动服务
    • 通过开始菜单可以启动,停止,卸载服务
  • 占用端口

    • 4369(集群、Erlang)
    • 5671,5672(应用层标准高级消息队列协议)
    • 25672(Erlang分发,CLI通信)
    • 15672(如果管理插件启用)
    • 61613,61614(如果消息文本协议STOMP已启用)
    • 1883,8883(如果erl实时通信已启用)
  • 支持的平台

    • 基于Ubuntu和Debian的Linux发行版
    • 基于Fedora,CentOS和RPM的Linux发行版
    • Mac OS X
    • Windows XP及更高版本

概念

  • Connections:客户端连接,创建该资源非常耗时,应尽量避免多次创建。

  • Channel:消息通道,在客户端的每个连接里,可建立多个channel,每个channel代表一个会话任务。

  • Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列。

  • Queue:消息队列载体,每个消息都会被投入到一个或多个队列。

  • Broker:简单来说就是消息队列服务器实体。

  • Binding:绑定,它的作用就是把exchange和queue按照路由规则绑定起来。

  • Routing Key:路由关键字,exchange根据这个关键字进行消息投递。

  • vhost:虚拟主机,一个broker里可以开设多个vhost,用作不同用户的权限分离。

  • producer:消息生产者,就是投递消息的程序。

  • consumer:消息消费者,就是接收消息的程序。

消息队列的发送过程大概如下:

  1. 客户端创建Connection,连接到消息队列服务器,打开一个channel。
  2. 客户端声明一个Exchange,并设置相关属性。
  3. 客户端声明一个Queue,并设置相关属性。
  4. 客户端使用routing key,在exchange和queue之间建立好绑定关系。
  5. 客户端发送消息首先到exchange
  6. exchange根据type路由到对应的队列(可以是多个队列)中.

Exchange Type

  • direct(直连)

    • routing key 与 binding key相同
  • fanout
    • 给所有绑定队列发送消息
  • topic
    • routing key:audit.irs.corporate => binding key:audit.#
    • routing key:audit.irs => binding key:audit.*
  • default
    • direct
    • binding key为queue名称

常用命令

  • 管理插件

    • rabbitmq-plugins enable rabbitmq_management // 启用
    • rabbitmq-plugins disable rabbitmq_management // 禁用
  • 管理队列

    • rabbitmqctl list_queues // 查看队列
  • 管理用户及权限

    • rabbitmqctl list_users // 查看所有用户
    • rabbitmqctl add_user user_admin passwd_admin // 添加用户
    • rabbitmqctl set_user_tags user_admin administrator // 添加权限
    • rabbitmqctl delete_user guest // 删除用户
    • rabbitmqctl change_password {username} {newpassowrd} // 修改密码
  • 管理虚拟主机vhost

    • rabbitmqctl add_vhost vhostpath // 创建虚拟主机
    • rabbitmqctl delete_vhost vhostpath // 删除虚拟主机
    • rabbitmqctl list_vhosts // 列出所有虚拟主机

使用

  • 发送消息(以持久化代码为例)
  1. var factory = new ConnectionFactory
  2. {
  3. HostName = hostName, // rabbit server
  4. UserName = "admin",
  5. Password = "admin",
  6. Port = 5672, // Broker端口
  7. VirtualHost = "/" // 虚拟Host,需提前配置
  8. };
  9. using (var connection = factory.CreateConnection()) // 创建与RabbitMQ服务器的连接
  10. {
  11. using (var channel = connection.CreateModel()) // 创建1个Channel(大部分API在该Channel中)
  12. {
  13. // 定义1个队列,自动会和默认的exchange 做direct类型绑定
  14. channel.QueueDeclare(
  15. queue: "hello", // 队列名称
  16. durable: true, // 队列是否持久化
  17. exclusive: false, // 排他队列:如果一个队列被声明为排他队列,该队列仅对首次声明它的连接可见,并在连接断开时自动删除。(活动在一次连接内)
  18. autoDelete: false, // 自动删除:当最后一个消费者取消订阅时,队列自动删除。如果您需要仅由一个使用者使用的临时队列,请将自动删除与排除。当消费者断​​开连接时,队列将被删除。(至少消费者能连一次)
  19. arguments: null); // 配置参数
  20. var randomQueue = channel.QueueDeclare(); // 定义随机的队列 该队列为临时队列(排他队列 + 自动删除)
  21. // 定义Exchange(一般而言,不需要定义exchange,rabbitmq默认创建了所有类型的exchange)
  22. //channel.ExchangeDeclare("direct-demo", ExchangeType.Direct); // 定义direct exchange
  23. //channel.ExchangeDeclare("fannout-demo", ExchangeType.Fanout); // 定义fanout exchange
  24. //channel.ExchangeDeclare("topic-demo", ExchangeType.Topic); // 定义fanout exchange
  25. // 定义queue exchange key 关系(在某些业务场景下,会使用该关系做路由功能)
  26. //channel.QueueBind(queue: "hello", exchange: "amq.direct", routingKey: "hello"); // 默认绑定的关系和该行代码效果一样
  27. //channel.QueueBind("hello", "amq.fanout", "hello"); // 该类型下的routingKey 实际不需要
  28. var properties = channel.CreateBasicProperties();
  29. properties.Persistent = true;
  30. while (true)
  31. {
  32. string message = "Hello World!" + DateTime.Now;
  33. var body = Encoding.UTF8.GetBytes(message);
  34. // 发送消息到队列中
  35. channel.BasicPublish(
  36. exchange: string.Empty, // 传递为Empty的时候,通过 `(AMQP default)`传递
  37. routingKey: "hello", // routing key 与 queuebind中的binding key对应
  38. basicProperties: properties, // 消息header
  39. body: body); // 消息body:发送的是bytes 可以任意编码
  40. Console.WriteLine(" [x] Sent {0}", message);
  41. }
  42. }
  43. }
  • 接收消息(以消息响应为例)
  1. var factory = new ConnectionFactory
  2. {
  3. HostName = hostName, // rabbit server
  4. UserName = "admin",
  5. Password = "admin",
  6. Port = 5672, // Broker端口
  7. VirtualHost = "/" // 虚拟Host,需提前配置
  8. };
  9. using (var connection = factory.CreateConnection())
  10. {
  11. using (var channel = connection.CreateModel())
  12. {
  13. var consumer = new EventingBasicConsumer(channel); // 创建Consumer
  14. consumer.Received += (model, ea) => // 通过回调函数异步推送我们的消息
  15. {
  16. var body = ea.Body;
  17. var message = Encoding.UTF8.GetString(body);
  18. Thread.Sleep(1000);
  19. channel.BasicAck(deliveryTag: ea.DeliveryTag, multiple: false); // 消息响应
  20. Console.WriteLine(" [x] Received {0}", message);
  21. };
  22. channel.BasicQos(0, 1, false); // 设置perfetchCount=1 。这样就告诉RabbitMQ 不要在同一时间给一个工作者发送多于1个的消息
  23. channel.BasicConsume(queue: "hello",
  24. noAck: false, // 需要消息响应(Acknowledgments)机制
  25. consumer: consumer);
  26. Console.WriteLine(" Press [enter] to exit.");
  27. Console.ReadLine();
  28. }
  29. }
  • 消息响应(acknowledgments)

    • 为了防止消息丢失,RabbitMQ提供了消息响应(acknowledgments)机制。消费者会通过一个ack(响应),告诉RabbitMQ已经收到并处理了某条消息,然后RabbitMQ才会释放并删除这条消息。
  • 持久化

    • 新队列(无法修改队列)配置为可持久化
    • 发送消息配置为持久化
    • 消息什么时候刷到磁盘?
      • 写入文件前会有一个Buffer,大小为1M,数据在写入文件时,首先会写入到这个Buffer,如果Buffer已满,则会将Buffer写入到文件(未必刷到磁盘)。
      • 固定的刷盘时间:25ms,也就是不管Buffer满不满,每个25ms,Buffer里的数据及未刷新到磁盘的文件内容必定会刷到磁盘。
      • 每次消息写入后,如果没有后续写入请求,则会直接将已写入的消息刷到磁盘:使用Erlang的receive x after 0实现,只要进程的信箱里没有消息,则产生一个timeout消息,而timeout会触发刷盘操作。

常见问题

  • RabbitMQ 管理插件启动报错

    • 确认RabbitMQ服务是否启动
    • C:\Windows目录下,将.erlang.cookie文件,拷贝到用户目录下 C:\Users{用户名},这是Erlang的Cookie文件,允许与Erlang进行交互
    • 重新安装erl 和 rabbit,尽量不要带空格的路径
  • 修改配置文件

[Open Source] RabbitMQ 安装与使用的更多相关文章

  1. Day11 Memcached、Redis和RabbitMQ安装

    修改Ubuntu镜像源: sudo vi /etc/apt/sources.list 全部替换为以下内容: ---------------------------------------------- ...

  2. RabbitMQ安装与初始配置

    [TOC] 本文只讨论linux下的Rabbitmq安装. Erlang安装 rabbitmq依赖于Erlang,需先安装,推荐安装rabbitmq/erlang-rpm: #clone源码 git ...

  3. Linux下RabbitMq安装

    在大多数大公司,像应用服务器软件的安装.部署都是运维的事情,其实自己去尝试部署一下,也是有收获的. 有机会正好尝试了Linux下的rabbitMq安装过程,做了记录,希望有用到的人可以做下参考. 安装 ...

  4. CentOS 7 rabbitmq 安装

    OS版本:CentOS 7.2Rrlang:19.2RabbitMQ:3.6.6 1.1 erlang安装 1. http://www.erlang.org/下载erlang,解压缩,进入目录,检查环 ...

  5. rabbitmq安装与高可用集群配置

    rabbitmq版本:3.6.12 rabbitmq安装 1.安装openssl wget http://www.openssl.org/source/openssl-1.0.0a.tar.gz &a ...

  6. rabbitmq安装及基本操作(含集群配置)

    一.rabbitmq的安装 因为rabbitmq是基于 erlang语言开发,所有要先安装erlang 1.安装erlang 这里我下载的是19.2的版本,地址为https://www.erlang. ...

  7. RabbitMQ安装 ubuntu12.04LTS

    RabbitMQ安装需要安装较多的依赖包,之前如果安装过RabbitMQ-server必须要先彻底删除. 重装的ubuntu系统(ubuntu server)的开发环境几乎是裸的,再重新编译安装erl ...

  8. centos7 rabbitmq安装以及应用

    安装单机rabbitmq   1.安装erlang cd /usr.local yum install wget yum install net-tools wget http://erlang.or ...

  9. 简述C#中IO的应用 RabbitMQ安装笔记 一次线上问题引发的对于C#中相等判断的思考 ef和mysql使用(一) ASP.NET/MVC/Core的HTTP请求流程

    简述C#中IO的应用   在.NET Framework 中. System.IO 命名空间主要包含基于文件(和基于内存)的输入输出(I/O)服务的相关基础类库.和其他命名空间一样. System.I ...

随机推荐

  1. Windows下Python读取GRIB数据

    之前写了一篇<基于Python的GRIB数据可视化>的文章,好多博友在评论里问我Windows系统下如何读取GRIB数据,在这里我做一下说明. 一.在Windows下Python为什么无法 ...

  2. CF 752C. Santa Claus and Robot

    C. Santa Claus and Robot time limit per test 2 seconds memory limit per test 256 megabytes input sta ...

  3. 一个想法(续三):一份IT技术联盟创业计划书,开启众筹创业征程

    写在创业计划书之前的话: 昨天在闪存里我@了dudu,说:我要借钱,不久dudu回了我:傍个富婆. 当然,dudu以为我是玩笑,其实,我的确是开玩笑的,哈. 不过我正在执行一个创业计划,如果启动,我会 ...

  4. 读书笔记 effective c++ Item 9 绝不要在构造函数或者析构函数中调用虚函数

    关于构造函数的一个违反直觉的行为 我会以重复标题开始:你不应该在构造或者析构的过程中调用虚函数,因为这些调用的结果会和你想的不一样.如果你同时是一个java或者c#程序员,那么请着重注意这个条款,因为 ...

  5. spring配置文件头部xmlns配置精髓

    <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w ...

  6. C++中将string类型转化为int类型

    写程序需要将string转化为int,所以就探索了一下. 方法一:atoi函数 atoi函数将字符串转化为整数,注意需要stdlib库.所以就尝试了一下: #include <iostream& ...

  7. Match类解析

    Matcher类:使用Matcher类,最重要的一个概念必须清楚:组(Group),在正则表达式中()定义了一个组,由于一个正则表达式可以包含很多的组,所以下面先说说怎么划分组的,以及这些组和组的下标 ...

  8. PHPCMS-后台管理中心

    这个就是便捷管理网页,可以通过这个后台进行修改.增删一些东西,还可以利用一些网页模板来建立网页 首先就是下载好这个后台管理中心,这个从网上下载就好了,记住这个要安装在WampServer中的www文件 ...

  9. wordPress查看站点时,显示文件目录

    1.在wordpress的代码目录中增加.htaccess文件. 2.在.htaccess文件中加入如下内容: DirectoryIndex index.php index.html# BEGIN W ...

  10. jQuery_第五章_事件和动画

    Jquery中的事件与动画 一.window.onload和$(document).read()的细微差别 (1)执行时机 window.onload:所有元素(包括元素的所有关联文件)完全加载到浏览 ...