`

[转]什么是AMQP

mq 
阅读更多
AMQP,即Advanced Message Queuing Protocol,一个提供统一消息服务的应用层标准高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同开发语言等条件的限制。Erlang中的实现有 RabbitMQ等。
中文名
高级消息队列协议
外文名
AMQP
属    性
应用层标准协议
应用领域
计算机

简介编辑

AMQP协议
第1章 概述
1.3. 摘要
1.3.1. 什么是AMQP
高级消息队列协议使得遵从该规范的客户端应用和消息中间件服务器的全功能互操作成为可能。
1.3.2. 为什么要用AMQP
我们的目标是实现一种在全行业广泛使用的标准消息中间件技术,以便降低企业和系统集成的开销,并且向大众提供工业级的集成服务。
我们的宗旨是通过AMQP,让消息中间件的能力最终被网络本身所具有,并且通过消息中间件的广泛使用发展出一系列有用的应用程序。
1.3.3. AMQP的范围
为了完全实现消息中间件的互操作性,需要充分定义网络协议和消息代理服务的功能语义。
因此,AMQP定义网络协议和代理服务如下:
一套确定的消息交换功能,也就是“高级消息交换协议模型”。AMQP模型包括一套用于路由和存储消息的功能模块,以及一套在这些模块之间交换消息的规则。
一个网络线级协议(数据传输格式),客户端应用可以通过这个协议与消息代理和它实现的AMQP模型进行交互通信。
可以只实现AMQP协议规范中的的部分语义,但是我们相信明确的描述这些语义有助于理解这个协议。

相关协议编辑

1.3.4.1. AMQP模型
我们需要明确的定义服务器的语义,因为所有服务器实现都应该保持这些语义的一致性,否则就无法进行互操作。
因此AMQP模型描述了一套模块化的组件以及这些组件之间进行连接的标准规则。
在服务器中,三个主要功能模块连接成一个处理链完成预期的功能:
“exchange”接收发布应用程序发送的消息,并根据一定的规则将这些消息路由到“消息队列”。
“message queue”存储消息,直到这些消息被消费者安全处理完为止。
“binding”定义了exchange和message queue之间的关联,提供路由规则。
使用这个模型我们可以很容易的模拟出存储转发队列和主题订阅这些典型的消息中间件概念。
一个AMQP服务器类似于邮件服务器,exchage类似于消息传输代理(email里的概念),message queue类似于邮箱。Binding定义了每一个传输代理中的消息路由表,发布者将消息发给特定的传输代理,然后传输代理将这些消息路由到邮箱中,消费者从这些邮箱中取出消息。
在以前的中间件系统的应用场景中,发布者直接将消息发送给邮箱或者邮件列表。
区别就在于用户可以控制message queue与exchage的连接规则,这可以做很多有趣的事情,比如定义一条规则:“将所有包含这样这样的消息头的消息都复制一份再发送到消息队列中”。
AMQP模型有以下目标:
支持金融服务领域的语义要求。
支持金融服务领域所要求的性能要求。
能够很方便的扩展新的消息路由和队列。
通过AMQP协议(AMQP和AMQP Protocol的是整体和部分的关系),服务器应用可以通过编程的方式来实现具体的功能语义。
简单而灵活。
1.3.4.2. AMQP协议
AMQP协议是一个二进制协议,拥有一些现代特点:多信道、协商式、异步、安全、跨平台、中立、高效。
AMQP通常被划分为三层:
模型层定义了一套命令(按功能分类),客户端应用可以利用这些命令来实现它的业务功能。
会话层负责将命令从客户端应用传递给服务器,再将服务器的应答传递给客户端应用,会话层为这个传递过程提供可靠性、同步机制和错误处理。
传输层提供帧处理、信道复用、错误检测和数据表示。
实现者可以将传输层替换成任意传输协议,只要不改变AMQP协议中与客户端应用程序相关的功能。实现者还可以使用其他高层协议中的会话层。
AMQP模型的设计由以下几个需求所驱动:
保证遵从AMQP规范的服务器实现之间能够进行互操作。
为服务质量提供显示控制。
支持所有消息中间件的功能:消息交换、文件传输、流传输、远程进程调用等。
兼容已有的消息API规范(比如Sun公司的JMS规范)。
形成一致和明确的命名。
通过AMQP协议可以完整的配置服务器线路(TODO:server wiring是啥意思?)。
使用命令符号可以很容易的映射成应用级别的API。
明确定义每一个操作只做一件事情。
AMQP传输层的设计由以下几个主要的需求所驱动,这些需求不分先后次序:
使用能够快速打包解包的二进制编码来保证数据的紧凑性。
能够处理任意大小的消息。
允许零拷贝数据传输(比如远程DMA)。
一个连接支持多个会话。
保证会话能够从网络错误、服务器失效中恢复。
为了长期存在,没有隐含的内置限制(TODO:To be long-lived,with no significant in-built limitations)。
异步传输消息。
能够很容易的处理新的和变化的需求。
高版本的AMQP规范能够兼容低版本的规范。
使用强断言模型来保证应用程序的可修复性。
保持编程语言的中立性。
适宜使用代码生成工具生成协议处理模块。

功能范围编辑

我们支持各种消息交换的体系结构:
存储转发(多个消息发送者,单个消息接收者)。
分布式事务(多个消息发送者,多个消息接收者)。
发布订阅(多个消息发送者,多个消息接收者)。
基于内容的路由(多个消息发送者,多个消息接收者)。
文件传输队列(多个消息发送者,多个消息接收者)。
点对点连接(单个消息发送者,单个消息接收者)。

文档结构编辑

本文档分成两个部分:
“概念”部分将对AMQP的概念做一个简单的介绍,描述AMQP怎么工作,以及AMQP的用途。
“标准”部分将对AMQP的模型层、会话层的每个组成部分做精确的定义,还将定义AMQP在网络上传输的二进制消息结构。
我们用IETF RFC2119中的术语定义:必须、不必、应该、不应该和可以(详见参考资料[1]  )。
当我们讨论遵从AMQP规范的服务器的具体行为时,我们使用术语“服务器”来表示这些服务器。
当我们讨论遵从AMQP规范的客户端应用的具体行为时,我们使用术语“客户端”来表示这些客户端应用。
我们使用“端点”来表示“服务器或者客户端”。
除非另有说明,所有数字都是十进制的。
协议中的常量都用大写字母的名字来表示。AMQP的实现如果需要在代码或者文档中定义和使用这些常量,必须用这些名字来表示。
属性名、命令或者控制参数,以及帧字段都用小写字母的名字来表示。AMQP的实现必须在代码或者文档中与之保持一致。
1.5. 约定
1.5.1. 定义
1.5.2. 版本号
AMQP版本用两个版本号表示——主版本号和次版本号。我们约定版本由主版本号后面加小数点再加上次版本号组成(比如1-3表示主版本号为1,次版本号为3)。
主版本号和次版本号可以用0到255之内的所有值。
主版本号保持不变,次版本号递增。当AMQP工作组提升主版本号时,次版本号将被设置为0。因此,有可能出现这样的版本序列:1-2,1-3,1-4,2-0,2-1……
一旦本协议发布之后(主版本号大于1),应尽量防止次版本号递增到9。不过在发布之前(版本0-x),由于会对本协议进行频繁的修订,可以不遵守这条约定。
一旦本协议发布之后(主版本号大于1),同一个主版本不同次版本的实现必须向后兼容。而在发布之前,这些次版本的实现不需要兼容。
大于或者等于99的主版本号用于测试和开发目的。

技术术语编辑

AMQP模型(AMQP Model):一个由关键实体和语义表示的逻辑框架,遵从AMQP规范的服务器必须提供这些实体和语义。为了实现本规范中定义的语义,客户端可以发送命令来控制AMQP服务器。
连接(Connection):一个网络连接,比如TCP/IP套接字连接。
会话(Session):端点之间的命名对话。在一个会话上下文中,保证“恰好传递一次”。
信道(Channel):多路复用连接中的一条独立的双向数据流通道。为会话提供物理传输介质。
客户端(Client):AMQP连接或者会话的发起者。AMQP是非对称的,客户端生产和消费消息,服务器存储和路由这些消息。
服务器(Server):接受客户端连接,实现AMQP消息队列和路由功能的进程。也称为“消息代理”。
端点(Peer):AMQP对话的任意一方。一个AMQP连接包括两个端点(一个是客户端,一个是服务器)。
搭档(Partner):当描述两个端点之间的交互过程时,使用术语“搭档”来表示“另一个”端点的简记法。比如我们定义端点A和端点B,当它们进行通信时,端点B是端点A的搭档,端点A是端点B的搭档。
片段集(Assembly):段的有序集合,形成一个逻辑工作单元。
段(Segment):帧的有序集合,形成片段集中一个完整子单元。
帧(Frame):AMQP传输的一个原子单元。一个帧是一个段中的任意分片。
控制(Control):单向指令,AMQP规范假设这些指令的传输是不可靠的。
命令(Command):需要确认的指令,AMQP规范规定这些指令的传输是可靠的。
异常(Exception):在执行一个或者多个命令时可能发生的错误状态。
类(Class):一批用来描述某种特定功能的AMQP命令或者控制。
消息头(Header):描述消息数据属性的一种特殊段。
消息体(Body):包含应用程序数据的一种特殊段。消息体段对于服务器来说完全不透明——服务器不能查看或者修改消息体。
消息内容(Content):包含在消息体段中的的消息数据。
交换器(Exchange):服务器中的实体,用来接收生产者发送的消息并将这些消息路由给服务器中的队列。
交换器类型(Exchange Type):基于不同路由语义的交换器类。
消息队列(Message Queue):一个命名实体,用来保存消息直到发送给消费者。
绑定器(Binding):消息队列和交换器之间的关联。
绑定器关键字(Binding Key):绑定的名称。一些交换器类型可能使用这个名称作为定义绑定器路由行为的模式。
路由关键字(Routing Key):一个消息头,交换器可以用这个消息头决定如何路由某条消息。
持久存储(Durable):一种服务器资源,当服务器重启时,保存的消息数据不会丢失。
临时存储(Transient):一种服务器资源,当服务器重启时,保存的消息数据会丢失。
持久化(Persistent):服务器将消息保存在可靠磁盘存储中,当服务器重启时,消息不会丢失。
非持久化(Non-Persistent):服务器将消息保存在内存中,当服务器重启时,消息可能丢失。
消费者(Consumer):一个从消息队列中请求消息的客户端应用程序。
生产者(Producer):一个向交换器发布消息的客户端应用程序。
虚拟主机(Virtual Host):一批交换器、消息队列和相关对象。虚拟主机是共享相同的身份认证和加密环境的独立服务器域。客户端应用程序在登录到服务器之后,可以选择一个虚拟主机。
下面这些术语在AMQP规范的上下文中没有特别的意义:
主题:通常指发布消息;AMQP规范用一种或多种交换器来实现主题。
服务:通常等同于服务器。AMQP规范使用“服务器”这个术语来兼容IETF的标准术语,并且明确了协议中每个部分的角色(两方也可能是AMQP服务)。
消息代理:等同于服务器。AMQP规范使用术语“客户端”和“服务器”来兼容IETF的标准术语。
转自 百度百科
分享到:
评论

相关推荐

    amqp-rpc-client:生产就绪的AMQP RPC客户端

    什么是amqp-rpc-client? 它是一种可立即投入生产,简单,基于承诺的且与回调兼容的AMQP RPC客户端。快速开始npm install amqp-rpc-client 然后: var AmqpRpcClient = require('amqp-rpc-client');var rpcClient = ...

    amqp:针对AMQP 0.9.1的客户端

    转到RabbitMQ客户端库 这是Go中具有RabbitMQ扩展名的AMQP 0.9.1客户端。 项目成熟度 该项目已在生产系统中使用了很多年。 它已经相当成熟并且功能齐全,并且截至2016年11月拥有。 将来的API更改不太可能,但有可能...

    ruote-amqp:车轮的 AMQP ParticipantListener 对

    ruote-amqp ruote-amqp 是一组让 ruote 引擎通过 AMQP 发布和/或接收消息的类。 最常见的用例是发布供 AMQP 消费者处理的工作项,并最终将它们接收回来以恢复流程。 另一个用例是在 AMQP 队列上侦听工作流启动请求。...

    rhea-promise:Rhea AMQP客户端上的承诺层

    土质承诺甲Promisified层上AMQP客户端。前提条件Node.js版本:6.x或更高版本。 我们仍然鼓励您在任何给定时间从安装最新的可用LTS版本。 始终安装最新可用的LTS版本的node.js是一个好习惯。 使用上的可用安装程序,...

    IoTHubGateway:使用AMQP Multiplex将设备发送到云消息的Azure IoT网关

    Azure IoT中心AMQP服务器网关示例特拉维斯(Travis):介绍构建IoT解决方案时,将任何设备连接到IoT中心的最佳方法是使用提供的之一直接将其连接。 Azure IoT中心支持多种协议,并提供从REST API到C,Python,Node....

    mudra:一个 irc 到 amqp 的东西

    数据包被发送到 sqs(类似 AMQP 的服务)。 mudra 本身对这些消息没有任何作用。 这个想法是,虽然 mudra 会消化这些数据包(将 irc 的自然语言界面转换为 commandlet),但其他人会从队列中消化它们。 例如,您...

    开源项目-NeowayLabs-wabbit.zip

    开源项目-NeowayLabs-wabbit.zip,转到AMQP模拟库

    edeposit.amqp.aleph_link_export:双向通信子系统,用于更新Aleph中的电子存款链接

    介绍 双向通信子系统,用于更新Aleph中的链接。 在Aleph中创建的链接无法通过... 然后将XML通过SCP复制到Aleph,进行处理,然后将得到的XML响应转换回AMQP消息。 文献资料 完整的模块文档和说明可在阅读文档中找到:

    rabbitmq-email:用于RabbitMQ的SMTP网关插件

    该插件使SMTP和AMQP 0-9-1可以互操作。 它可以 将收到的电子邮件转换为AMQP 0-9-1消息 消耗AMQP 0-9-1消息并发送电子邮件 与其他协议(即STOMP)的某些互操作性也可以实现。 此实现旨在替换插件。 它基于更高级的而...

    酒店客房管理系统源码java-SpringBootRabitMq:有一个房间消息的生产者和消费者,ptogucer从餐厅应用程序获取并从消费者

    单击此链接转到下载和安装部分。 您将获得一些适用于不同操作系统类型的下载和安装选项。 选择适合您使用的操作系统的一种,然后继续下载和安装。 请注意,RabbitMQ 还需要安装 Erlang 才能使其工作。 您可以在此...

    物联网通讯协议

    物联网的各种通讯协议介绍,包含MQTT、 DDS、 AMQP、XMPP、 JMS、 REST、 CoAP等协议。

    azure-event-hubs-go:Azure事件中心的Golang客户端库https:azure.microsoft.comservicesevent-hubs

    该库是基于AMQP的Azure事件中心的纯Golang实现。 使用Go模块安装 如果要使用稳定版本的库,请使用Go模块。 注意:3.0.0之前的版本取决于pack.ag/amqp,此版本不再维护。 任何新代码都不应使用3.0.0之前的版本。 ...

    pgsql-listen-exchange:发布从PostgreSQL通知接收的消息的RabbitMQ Exchange

    PostgreSQL LISTEN交换RabbitMQ交换类型,它将PostgreSQL NOTIFY消息转换为AMQP消息并将其发布到绑定的队列中。 PostgreSQL NOTIFY消息通道用作使用直接交换样式路由机制的消息的路由键。 例子要将Postgres通知作为...

    PHP异步进程助手async-helper

    简介 PHP 的异步进程助手,借助于 AMQP 实现异步执行 ... ext-amqp 1.9.1+ ext-memcached 3.0.3+ 安装 通过 composer 安装 composer require l669/async-helper 或直接下载项目源码 wget https://github.com/l6

    springboot学习思维笔记.xmind

    什么是SpringBoot SpringBoot核心功能 独立运行的Spring项目 内嵌Servlet容器 提供Starter简化Maven配置 自动配置Spring 准生产的应用监控 无代码声称和xml配置 SpringBoot的优...

    module-ballerinax-rabbitmq:BallerinaRabbitMQ模块

    该模块包含支持与RabbitMQ代理进行消息传递的功能(AMQP 0-9-1)。 有关该模块支持的操作的更多信息(包括以下内容),请转到。 连接到RabbitMQ 使用交换和队列 发布消息 使用消费者服务消费消息 客户致谢 有关...

    go:Golang服务的通用代码

    Amqp : 用以连接 RabbitMQ 等接受 amqp 协议的 message queue BitMapCache 系列 : 一个内存位图缓存服务。比如需要表示QQ号是否在线等7种状态,可以创建一个4位缓存。如仅表示两种状态,1位的缓存足矣。在使用1位...

    情感分析微博服务示例:一个示例应用程序,演示了如何构建图形处理平台来分析Twitter上的情感影响源

    情绪分析Twitter微服务示例一个示例应用程序,演示了...Spring启动服务排名仪表板发现服务配置服务Twitter爬虫支持服务Neo4j(螺栓) RabbitMQ(AMQP) Twitter API(HTTP) Google Cloud Language API(HTTP)图处理平

    cortside.domainevent

    使用AMQPNETLITE(AMQP 1. 0协议)。 Azure ServiceBus 一般的 授权密钥不能包含“ /”。 如果必须重新生成它们。 AMQPNETLITE不喜欢该值。 如果使用AzureSB UI创建主题和队列,我会发现行为不一致。 我使用...

Global site tag (gtag.js) - Google Analytics