您的当前位置:首页>全部文章>文章详情

【PHP】RabbitMQ简介

CrazyPanda发表于:2024-06-11 18:04:33浏览:249次TAG:

1. RabbitMQ简介

AMQP,即Advanced Message Queuing Protocol,高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。消息中间件主要用于组件之间的解耦,消息的发送者无需知道消息使用者的存在,反之亦然。

AMQP的主要特征是面向消息、队列、路由(包括点对点和发布/订阅)、可靠性、安全。

AMQP 中消息的路由过程和 Java 开发者熟悉的 JMS 存在一些差别,AMQP 中增加了 Exchange 和 Binding 的角色。生产者把消息发布到 Exchange 上,消息最终到达队列并被消费者接收,而 Binding 决定交换器的消息应该发送到那个队列。

RabbitMQ是一个开源的AMQP实现,服务器端用Erlang语言编写,支持多种客户端,如:Python、Ruby、.NET、Java、JMS、C、PHP、ActionScript、XMPP、STOMP等,支持AJAX。用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。

2. 模型

 RabbitMQ的模型结构,主要由以下几部分构成:

  • Message
    消息,消息是不具名的,它由消息头和消息体组成。消息体是不透明的,而消息头则由一系列的可选属性组成,这些属性包括routing-key(路由键)、priority(相对于其他消息的优先权)、delivery-mode(指出该消息可能需要持久性存储)等。

  • Producer
    消息的生产者,也是一个向交换器发布消息的客户端应用程序。

  • Exchange
    交换器,用来接收生产者发送的消息并将这些消息路由给服务器中的队列。

  • Binding
    绑定,用于消息队列和交换器之间的关联。一个绑定就是基于路由键将交换器和消息队列连接起来的路由规则,所以可以将交换器理解成一个由绑定构成的路由表。

  • Queue
    消息队列,用来保存消息直到发送给消费者。它是消息的容器,也是消息的终点。一个消息可投入一个或多个队列。消息一直在队列里面,等待消费者连接到这个队列将其取走。

  • Virtual Host
    虚拟主机,表示一批交换器、消息队列和相关对象。虚拟主机是共享相同的身份认证和加密环境的独立服务器域。每个 vhost 本质上就是一个 mini 版的 RabbitMQ 服务器,拥有自己的队列、交换器、绑定和权限机制。vhost 是 AMQP 概念的基础,必须在连接时指定,RabbitMQ 默认的 vhost 是 / 。

  • Broker
    表示消息队列服务器实体。

  • Virtual Host
    虚拟主机,表示一批交换器、消息队列和相关对象。当多个不同的用户使用同一个RabbitMQ server提供的服务时,可以划分出多个vhost,每个用户在自己的vhost创建并拥有自己的队列、交换器、绑定和权限机制。

  • Broker
    表示消息队列服务器实体,其作用是维护一条从Producer到Consumer的路线,保证数据能够按照指定的方式进行传输。

  • Connection
    网络连接,比如一个TCP连接,Producer和Consumer都是通过TCP连接到RabbitMQ Server的。

  • Channel
    信道,多路复用连接中的一条独立的双向数据流通道。信道是建立在真实的TCP连接内地虚拟连接,AMQP 命令都是通过信道发出去的,不管是发布消息、订阅队列还是接收消息,这些动作都是通过信道完成。因为对于操作系统来说建立和销毁 TCP 都是非常昂贵的开销,所以引入了信道的概念,以复用一条 TCP 连接。

  • Consumer
    消息的消费者,表示一个从消息队列中取得消息的客户端应用程序。

生产者发送消息流程:

  1. Producer和Broker建立TCP连接。

  2. Producer和Broker建立通道。

  3. Producer通过通道消息发送给Broker,由Exchange将消息进行转发。

  4. Exchange将消息转发到指定的Queue(队列)


消费者接收消息流程:

  1. Consumer和Broker建立TCP连接

  2. Consumer和Broker建立通道

  3. Consumer监听指定的Queue(队列)

  4. 当有消息到达Queue时Broker默认将消息推送给Consumer。

  5. Consumer接收到消息。

  6. ACK回复(Consumer发送回执)

注:RabbitMQ收到消息回执(Message acknowledgment)后才将该消息从Queue中移除;如果RabbitMQ没有收到回执并检测到消费者的RabbitMQ连接断开,则RabbitMQ会将该消息发送给其他消费者(如果存在多个消费者)进行处理。这里不存在timeout概念,一个消费者处理消息时间再长也不会导致该消息被发送给其他消费者,除非它的RabbitMQ连接断开。


3. Exchange类型

Exchange分发消息时根据类型的不同分发策略有区别,目前共四种类型:direct、fanout、topic、headers 。

3.1 direct

direct 交换器:消息中的路由键(routing key)如果和 Binding 中的 binding key 一致, 交换器就将消息发到对应的队列中。

路由键与队列名完全匹配,如果一个队列绑定到交换机要求路由键为“dog”,则只转发 routing key 标记为“dog”的消息,不会转发“dog.puppy”,也不会转发“dog.guard”等等。它是完全匹配、单播的模式。

3.2 fanout

fanout 交换器:每个发到 fanout 类型交换器的消息都会分到所有绑定的队列上去。

fanout 交换器不处理路由键,只是简单的将队列绑定到交换器上,每个发送到交换器的消息都会被转发到与该交换器绑定的所有队列上。很像子网广播,每台子网内的主机都获得了一份复制的消息。fanout 类型转发消息是最快的。

3.3 topic

topic类型的Exchange在匹配规则上进行了扩展,它与direct类型的Exchage相似,也是将消息路由到binding key与routing key相匹配的Queue中,但这里的匹配规则有些不同,它约定:

  • routing key为一个句点号“. ”分隔的字符串(我们将被句点号“.”分隔开的每一段独立的字符串称为一个单词),如“usa.news”、“usa.weather”等;

  • binding key与routing key一样也是句点号“.”分隔的字符串;

  • binding key中可以存在两种特殊字符“*”与“#”,用于做模糊匹配,其中“*”用于匹配一个单词,“#”用于匹配多个单词(可以是零个)。

3.4 headers

headers类型的Exchange不依赖于routing key与binding key的匹配规则来路由消息,而是根据发送的消息内容中的headers属性进行匹配。
在绑定Queue与Exchange时指定一组键值对;当消息发送到Exchange时,RabbitMQ会取到该消息的headers(也是一个键值对的形式),对比其中的键值对是否完全匹配Queue与Exchange绑定时指定的键值对;如果完全匹配则消息会路由到该Queue,否则不会路由到该Queue。
该类型的Exchange没有用到过(不过也应该很有用武之地),所以不做介绍。


以上就是本次RabbitMQ的全部内容。


猜你喜欢

【PHP】TP使用endroid/qr-code生成二维码
前言TP版本:TP6.0Packagist 传送地址: https://packagist.org/packages/endroid/qr-code使用前需要检查下是否启用了 gd2 扩展,对于 endroid/qr-code 版本选择,参考扩展包文档对 PHP 版本的要求1、 安装扩展执行 composer 命令安装 endroid/qr-code 扩展composer require endroid/qr-code2、 使用builder生成器use Endro
发表于:2024-03-08 浏览:348 TAG:
【PHP】哪些函数会影响php探针
影响php探针的函数有ini_set()、error_reporting()、set_time_limit()、memory_limit()、exec()、eval()、disable_functions等等。详细介绍:1、ini_set()函数,用于动态地设置PHP的配置选项,可以在运行时修改php.ini文件中的配置;2、error_reporting()函数等等。本教程操作系统:windows10系统、PHP8.1.3版本、Dell G3电脑。PHP探针是一种用于检测和分析服务器
发表于:2023-12-06 浏览:386 TAG:
【PHP】PHP8中如何使用Stringable Interface更方便地处理字符串操作
PHP8中如何使用Stringable Interface更方便地处理字符串操作?PHP8是PHP语言的最新版本,带来了许多新特性和改进。其中一项令开发者欢欣鼓舞的改进之一就是Stringable Interface的加入。Stringable Interface是一个用于处理字符串操作的接口,它提供了一种更方便的方式来处理和操作字符串。本文将详细介绍如何使用Stringable Interface来提升字符串操作的便捷性,并提供具体的代码示例。首先,让我们了解一下Stringable Inte
发表于:2023-12-30 浏览:336 TAG:
【PHP】php如何将utf8转gbk编码
随着互联网的发展,跨语言交流和国际化成为了越来越普遍的需求。由于不同的编码方式,网站之间的数据传输和处理也变得越来越复杂。在这个过程中,一些老旧的编码方式依然在使用,比如GBK编码。为了兼容各种编码方式,php提供了一些内置函数来进行编码转换,本文将介绍如何将utf8编码转换成GBK编码。一、了解编码首先,我们需要了解utf8和GBK编码分别是什么。utf8是一种可变长度的字符编码,是国际标准化组织ISO的一部分,也是Unicode字符集的一种实现方式。utf8编码可以容纳所有Unic
发表于:2023-12-20 浏览:320 TAG:
【PHP】ThinkPHP6中间件介绍
一、什么是中间件?当客户端发送请求至服务器时,HTTP请求会经过多个中间件,最后返回响应给客户端。中间件可以在请求到达目标控制器或动作之前对请求进行操作可以在响应离开目标控制器或动作之前对响应进行操作二、中间件的作用我们可以在不修改应用程序逻辑的情况下添加额外的功能,如登录验证、检查用户权限、权限控制请求过滤判断当前浏览器环境是在微信或支付宝写系统日志统计三、中间件的类型1、前置中间件前置中间件的意思就是,在http请求完成之前,先执行中间件的代码。一般用来检查用户权限在app/middlewa
发表于:2024-07-29 浏览:251 TAG: #php #thinkphp #中间件
【PHP】php哪些函数可以用来去幂方值
hp可以用来去幂方值的函数有pow函数、双星号、exp函数、sqrt函数和log函数等。详细介绍:1、pow函数用于计算x的y次幂,x是底数,y是指数;2、双星号是幂运算符,用于计算一个数的幂;3、exp函数用于计算以e为底的x次幂,e是自然对数的底数,x是指数;4、sqrt函数用于计算一个数的平方根,x是计算平方根的数;5、log函数用于计算以指定底数为底的对数。本教程操作系统:windows10系统、PHP 8.1.3版本、DELL G3电脑。在PHP中,可以使用一些内置的函数来进行幂运算
发表于:2024-03-15 浏览:279 TAG:
【PHP】nginx负载均衡器的部署(5层\7层)
目录什么是负载均衡?实验:实现Web业务的负载均衡(http协议负载均衡)一、实验规划图:如何实现克隆虚拟机呢?二、实验步骤:1、准备4台服务器,一台做负载均衡器,另外的3台做web服务器,每台都需要安装nginx,建议都编译安装nginx,统一安装配置2、安装nginx成功后配置nginx里的网页,使之呈现对应的效果3、修改四台linux机器的名字:4、检查配置是否成功5、对n
发表于:2024-05-29 浏览:360 TAG:
【PHP】php中几个不常用的函数方法
1.abs():返回一个数的绝对值;2.set_time_limit :设置脚本最大执行时间(如果设置为0则没有时间限制,默认值为30秒,或者是在php.ini的max_execution_time被定义的值,如果此值存在。);3.strip_tags($str,'<p><a>'):剥去除p和a标签外的字符串中、XML 以及 PHP 的标签;4.iconv():字符串按要求的字符编码来转换;5.is_dir():检查目录是否存在;6.mkdir():创建文
发表于:2024-08-02 浏览:297 TAG:
【PHP】php 实现打印文档功能
在许多网站中,我们经常会看到打印文档的功能,用户可以通过点击打印按钮将页面内容打印出来。传统的实现方式是通过浏览器自带的打印功能进行操作,但是这种方式存在很多弊端,比如样式不一致、图片显示异常等问题。为了解决这些问题,可以使用PHP来实现打印文档功能。实现思路使用PHP实现打印文档功能的基本思路是,将需要打印的内容通过服务器端的脚本转化为PDF文档,再通过浏览器下载或直接打印该PDF文件。具体实现步骤如下:1.获取需要打印的内容在PHP中,我们可以使用$_POST或$_GET获取需要打
发表于:2023-12-29 浏览:308 TAG:
【PHP】PHP实现图片验证码的生成和验证
PHP实现图片验证码的生成和验证在网站开发中,为了防止机器恶意攻击或者自动注册,我们经常会使用图片验证码来进行验证。本文将介绍如何使用PHP来生成和验证图片验证码,并给出具体的代码示例。生成图片验证码生成图片验证码的关键是生成随机的验证码字符串,并将其绘制到图片上。以下是一个生成图片验证码的示例代码:<?php session_start();   // 声明图片尺寸 $image_width = 100; $image_height&nb
发表于:2023-12-28 浏览:287 TAG: