zoukankan      html  css  js  c++  java
  • 第一节 初识RabbitMQ

    原文:第一节 初识RabbitMQ

          版权声明:未经本人同意,不得转载该文章,谢谢          https://blog.csdn.net/phocus1/article/details/87280120        </div>
            <link rel="stylesheet" href="https://csdnimg.cn/release/phoenix/template/css/ck_htmledit_views-f57960eb32.css">
                              <link rel="stylesheet" href="https://csdnimg.cn/release/phoenix/template/css/ck_htmledit_views-f57960eb32.css">
          <div class="htmledit_views" id="content_views">
            <p><strong>1.什么是RabbitMQ</strong>:(<a href="https://baike.baidu.com/item/rabbitmq/9372144" rel="nofollow">百度百科</a>)RabbitMQ是实现了高级消息队列协议(<a href="https://baike.baidu.com/item/AMQP" rel="nofollow">AMQP</a>)的开源消息代理软件(亦称面向消息的中间件)。RabbitMQ服务器是用<a href="https://baike.baidu.com/item/Erlang" rel="nofollow">Erlang</a>语言编写的,而群集和故障转移是构建在开放电信平台框架上的。所有主要的编程语言均有与代理接口通讯的客户端库。</p>
    

    2.官网网址:http://www.rabbitmq.com

    3.Windows下安装RabbitMQ和Erlang:

    安装RabbitMQ之前需要先安装Erlang(并且注意版本的匹配),RabbitMQ下载地址:http://www.rabbitmq.com/install-windows.html ,如下图所示:

    此处我们选择rabbitmq-server-3.7.8版本,对应的Erlang版本查看下面地址进行选择:http://www.rabbitmq.com/which-erlang.html,如下图所示:

    由上图可知,可下载21.0.x版本的Erlang,下载地址如下:http://www.erlang.org/downloads

     

    Erlang安装过程:

    安装路径选择:D:Program Fileserl10.1:

    安装完成后,可检查环境变量(如没有,则手动添加):

    接下来安装RabbitMQ,如下图所示:

    安装目录:D:Program FilesRabbitMQ Server

    4.RabbitMQ 特点

    RabbitMQ 是一个由 Erlang 语言开发的 AMQP 的开源实现。

    AMQP :Advanced Message Queue,高级消息队列协议。它是应用层协议的一个开放标准,为面向消息的中间件设计,基于此协议的客户端与消息中间件可传递消息,并不受产品、开发语言等条件的限制。

    RabbitMQ 最初起源于金融系统,用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。具体特点包括:

    • 可靠性(Reliability)

    RabbitMQ 使用一些机制来保证可靠性,如持久化、传输确认、发布确认。

    • 灵活的路由(Flexible Routing)

    在消息进入队列之前,通过 Exchange 来路由消息的。对于典型的路由功能,RabbitMQ 已经提供了一些内置的 Exchange 来实现。针对更复杂的路由功能,可以将多个 Exchange 绑定在一起,也通过插件机制实现自己的 Exchange 。

    • 消息集群(Clustering)

    多个 RabbitMQ 服务器可以组成一个集群,形成一个逻辑 Broker 。

    • 高可用(Highly Available Queues)

    队列可以在集群中的机器上进行镜像,使得在部分节点出问题的情况下队列仍然可用。

    • 多种协议(Multi-protocol)

    RabbitMQ 支持多种消息队列协议,比如 STOMP、MQTT 等等。

    • 多语言客户端(Many Clients)

    RabbitMQ 几乎支持所有常用语言,比如 Java、.NET、Ruby 等等。

    • 管理界面(Management UI)

    RabbitMQ 提供了一个易用的用户界面,使得用户可以监控和管理消息 Broker 的许多方面。

    • 跟踪机制(Tracing)

    如果消息异常,RabbitMQ 提供了消息跟踪机制,使用者可以找出发生了什么。

    • 插件机制(Plugin System)

    RabbitMQ 提供了许多插件,来从多方面进行扩展,也可以编写自己的插件。

    参考学习地址:https://www.jianshu.com/p/8bfbcb2eff54

     

  • 相关阅读:
    如何批量删除Redis数据库中的Key
    关于 no device found for connection ‘ System eth0′问题
    nginx配置vhost配置文件详解
    Linux教程之:Nginx [emerg]: bind() to 0.0.0.0:80 failed (98: Address already in use)
    Nginx配置文件详细说明
    swoole使用 常用案例
    超好用的一个JQUERY分页器-jpaginate
    如何解决chrome 等浏览器不支持本地ajax请求的问题
    PHP设计模式之单例模式
    IE和其他浏览器用JS新窗口打开的问题
  • 原文地址:https://www.cnblogs.com/owenzh/p/11087927.html
Copyright © 2011-2022 走看看