• 技术文章 >后端开发 >php教程

    什么是RabbitMQ?RabbitMQ的简单介绍

    青灯夜游青灯夜游2019-03-28 14:39:26转载1121
    本篇文章带来的内容是介绍RabbitMQ,让大家了解一些RabbitMQ的相关知识。有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

    RabbitMQ概览

    RabbitMQ是一个高性能的分布式消息中间件。它由Erlang编写,这种语言天生支持分布式,而且性能极高(但是比较难上手)。

    通信概念

    RabbitMQ简单理解就是一个队列服务,我们的生产者不断地往它投递消息,而消费者不断地从它那里获取消息。但相较于利用redis的List这类简单队列,RabbitMQ的消息投递更灵活一点。首先需要知道一些RabbitMQ中的通信概念:

     ● exchange(交换器)

     ● queue(队列):消息队列载体,每个消息都会被投入到一个或多个队列。

     ● binding(绑定):它的作用就是把exchange和queue按照路由规则绑定起来。

     ● routing key(路由关键字):exchange根据这个关键字进行消息投递。

     ● vhost(虚拟主机):不同的vhost下,数据完全隔离,默认vhost为“/”

     ● channel(信道):在一个tcp连接下,可建立多个channel,每个channel代表一个会话任务。

     ● producer(生产者)

     ● consumer(消费者)

    RabbitMQ中Exchange类似于一个路由器,我们的consumer并不会把消息直接投递给队列,而是投递给exchangeexchange根据我们投递时的路由键(routing key)再发送到特定的队列。这样的设计让消息可以灵活选路,发送到某一类的队列中,形成一对多的关系,而不仅仅是一对一。

    Exchange

    所以说RabbitMQ中的exchange很方便,很强大,它有这样几种类型:

     ● direct

     ● fanout

     ● topic

     ● headers(几乎用不到)

    direct交换器很简单,有时候我们仅仅需要一个很简单的队列(消息投递到其中,然后不断消费它),这时候我们就可以用direct交换器,它的规则是:如果路由键匹配,消息就会被投递到对应的队列。

    1.png

    fanout交换器忽略路由键,把消息同时发到一批队列。

    2.png

    topic则就是根据不同路由键,把消息发送到某一类队列中。

    3.png

    相关视频教程推荐:《PHP教程

    以上就是本篇文章的全部内容,希望能对大家的学习有所帮助。更多精彩内容大家可以关注php中文网相关教程栏目!!!

    以上就是什么是RabbitMQ?RabbitMQ的简单介绍的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:segmentfault 思否,如有侵犯,请联系admin@php.cn删除
    专题推荐:php7 php node.js rabbitmq
    上一篇:工厂模式与内存分配之间有什么联系? 下一篇:CodeIgniter3.0+框架自定义异常处理的方法介绍
    大前端线上培训班

    相关文章推荐

    • centos7安装rabbitmq的实例教程• RabbitMQ-镜像队列配置的介绍• PHP和RabbitMQ实现消息队列的完整代码• 深入理解PHP7内核之zval

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网