RabbitMQ练习(AMQP 0-9-1 Overview)

news2024/9/17 8:41:46

1、What is AMQP 0-9-1

AMQP 0-9-1(高级消息队列协议)是一种网络协议,它允许遵从该协议的客户端(Publisher或者Consumer)应用程序与遵从该协议的消息中间件代理(Broker,如RabbitMQ)进行通信。

AMQP 0-9-1模型的核心概念包括消息发布者(producers/publisher)、消息(messages)、交换机(exchanges)、队列(queues)、绑定(bindings)和消费者(consumers)

2、Brokers and Their Role

消息代理(Broker)接收来自发布者(发布消息的应用程序,也称为生产者)的消息,并将它们路由到消费者(处理这些消息的应用程序)。

由于它是一种网络协议,发布者、消费者和代理都可以位于不同的机器上。

3、AMQP 0-9-1 Model in Brief

  • P(Publisher)发布消息必须首先到达X(Exchange),发送的消息带有routing key。
  • Q(Queue)通过binding key和交换机绑定。
  • Exchange收到消息后,根据Exchange的类型,处理方式不同。如果是Direct Exchange,消息的routing key和binding key如果匹配,消息则copy到相应的队列。
  • C(consumer)通过订阅(Subscribe)该队列的消息或者Pull/fetch该队列的消息,该队列的消息最终发往相应的consumer。

队列、交换机和绑定一起组成AMQP实体。(原文:Queues, exchanges and bindings are collectively referred to as AMQP entities.)

4、AMQP 0-9-1 is a Programmable Protocol 

AMQP 0-9-1是一个可编程的协议,AMQP 0-9-1实体(实体包括Queues,exchanges and bindings)和消息路由方案主要是由需要使用消息代理的应用程序自己定义的,而不是由消息代理定义。AMQP 0-9-1协议支持声明队列和交换机、定义它们之间的绑定关系、订阅队列等操作,这赋予了应用程序开发者很大的自由度。

5、Exchange类型

  • Default Exchange:如果发送消息时,不指定Exchange,则该message发送到Default Exchange。Default Exchange类型是Direct Exchange。
  • Direct Exchange:队列使用binding key和Exchange绑定。Publisher发送携带routing key的消息到Exchange,如果routing key和binding key匹配,消息将copy到该队列。
  • Fanout Exchange:Fanout Exhcange会把收到的message,发送给所有和它绑定的队列,忽略routing key。
  • Topic Exchange:和Direct Exchange类似,但binding key是个匹配模板,routing key只要和该模板匹配即可。比如binding key是“#”,表示匹配任何routing key。
  • Header Exchange:消息Header中的信息,和binding key匹配,忽略rouging key。

Example:“Hello World!”——default exchange:

发布消息未指明exchange,使用default exchange:

Frame 79: 88 bytes on wire (704 bits), 88 bytes captured (704 bits) on interface docker0, id 0
Ethernet II, Src: 02:42:ac:11:00:03 (02:42:ac:11:00:03), Dst: 02:42:ac:11:00:02 (02:42:ac:11:00:02)
Internet Protocol Version 4, Src: 172.17.0.3 (172.17.0.3), Dst: 172.17.0.2 (172.17.0.2)
Transmission Control Protocol, Src Port: 37258, Dst Port: 5672, Seq: 382, Ack: 597, Len: 22
Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 1
    Length: 14
    Class: Basic (60)
    Method: Publish (40)
    Arguments
        Ticket: 0
        Exchange:    <---- no name,使用default exchange,类型为direct exchange
        Routing-Key: hello
        .... ...0 = Mandatory: False
        .... ..0. = Immediate: False

 6、Queues

队列(queues)用于存储由应用程序消费的消息。队列与交换机共享一些属性,但也具有一些额外的属性:

  • 名称(Name)
  • 持久性(Durable),即队列将在代理重启后继续存在。
  • 独占性(Exclusive),即队列只能被一个连接(connection)使用,当该连接关闭时队列将被删除。
  • 自动删除(Auto-delete),即至少有一个消费者订阅过的队列,在最后一个消费者取消订阅时将被删除。
  • 参数(Arguments),这是可选的,被插件和代理特定的特性使用,例如消息存活时间(TTL)、队列长度限制等。

在使用队列之前,必须先声明队列(queue declare)。如果队列尚不存在的话,声明队列将导致创建队列。如果队列已经存在,并且其属性与声明中的属性相同,则声明将不会产生任何效果。

发布者和消费者都可以声明同一个队列,确保消息发布前队列存在。

Example:“Hello World!” —— queue declare

声明创建名称为”hello”的队列。

Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 1
    Length: 17
    Class: Queue (50)
    Method: Declare (10)
    Arguments
        Ticket: 0
        Queue: hello
        .... ...0 = Passive: False
        .... ..0. = Durable: False
        .... .0.. = Exclusive: False
        .... 0... = Auto-Delete: False
        ...0 .... = Nowait: False
        Arguments

Example:“Publish/Subscribe” —— 临时队列

Frame 20: 86 bytes on wire (688 bits), 86 bytes captured (688 bits) on interface docker0, id 0
Ethernet II, Src: 02:42:ac:11:00:04 (02:42:ac:11:00:04), Dst: 02:42:ac:11:00:02 (02:42:ac:11:00:02)
Internet Protocol Version 4, Src: 172.17.0.4 (172.17.0.4), Dst: 172.17.0.2 (172.17.0.2)
Transmission Control Protocol, Src Port: 40738, Dst Port: 5672, Seq: 388, Ack: 583, Len: 20
Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 1
    Length: 12
    Class: Queue (50)
    Method: Declare (10)
    Arguments
        Ticket: 0
        Queue:    < -------- no name
        .... ...0 = Passive: False
        .... ..0. = Durable: False
        .... .1.. = Exclusive: True
        .... 0... = Auto-Delete: False
        ...0 .... = Nowait: False
        Arguments


Frame 21: 117 bytes on wire (936 bits), 117 bytes captured (936 bits) on interface docker0, id 0
Ethernet II, Src: 02:42:ac:11:00:02 (02:42:ac:11:00:02), Dst: 02:42:ac:11:00:04 (02:42:ac:11:00:04)
Internet Protocol Version 4, Src: 172.17.0.2 (172.17.0.2), Dst: 172.17.0.4 (172.17.0.4)
Transmission Control Protocol, Src Port: 5672, Dst Port: 40738, Seq: 583, Ack: 408, Len: 51
Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 1
    Length: 43
    Class: Queue (50)
    Method: Declare-Ok (11)
    Arguments
        Queue: amq.gen-n1_VgX3pWoYEt6CV9STq8A <--- broker给起的临时名字,amp开头
        Message-Count: 0
        Consumer-Count: 0

7、Bindings

队列通过绑定键和exchange绑定。exchange收到message以后,根据message携带的routing key和binding key匹配,决定把message从哪个队列发出。

另外,队列声明后创建队列,缺省会以该队列的名字为绑定键和default exchange进行绑定。

Example:"Hello World!" ——Binding

1、Consumer声明队列,名字为hello

Frame 16: 91 bytes on wire (728 bits), 91 bytes captured (728 bits) on interface docker0, id 0
Ethernet II, Src: receiver (02:42:ac:11:00:04), Dst: rabbitmq (02:42:ac:11:00:02)
Internet Protocol Version 4, Src: receiver (172.17.0.4), Dst: rabbitmq (172.17.0.2)
Transmission Control Protocol, Src Port: 47890, Dst Port: 5672, Seq: 357, Ack: 571, Len: 25
Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 1
    Length: 17
    Class: Queue (50)
    Method: Declare (10)
    Arguments
        Ticket: 0
        Queue: hello
        .... ...0 = Passive: False
        .... ..0. = Durable: False
        .... .0.. = Exclusive: False
        .... 0... = Auto-Delete: False
        ...0 .... = Nowait: False
        Arguments

2、rabbitmq创建hello队列,并且通过hello绑定键和default exchage绑定

root@7c53a5705902:/# rabbitmqctl list_queues
Timeout: 60.0 seconds ...
Listing queues for vhost / ...
name    messages
hello   0    <-----创建的队列
root@7c53a5705902:/# rabbitmqctl list_exchanges
Listing exchanges for vhost / ...
name    type
amq.topic       topic
amq.fanout      fanout
amq.direct      direct
amq.headers     headers
amq.match       headers
amq.rabbitmq.trace      topic
        direct
root@7c53a5705902:/# rabbitmqctl list_bindings
Listing bindings for vhost /...
source_name     source_kind     destination_name        destination_kind        routing_key     arguments
        exchange        hello   queue   hello   []  <---绑定键为hello
root@7c53a5705902:/# 

3、publisher(sender)发布消息,routing key为hello,未指定exchange(使用default exchange)

Frame 42: 88 bytes on wire (704 bits), 88 bytes captured (704 bits) on interface docker0, id 0
Ethernet II, Src: sender (02:42:ac:11:00:03), Dst: rabbitmq (02:42:ac:11:00:02)
Internet Protocol Version 4, Src: sender (172.17.0.3), Dst: rabbitmq (172.17.0.2)
Transmission Control Protocol, Src Port: 48864, Dst Port: 5672, Seq: 382, Ack: 597, Len: 22
Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 1
    Length: 14
    Class: Basic (60)
    Method: Publish (40)
    Arguments
        Ticket: 0
        Exchange:  <--- 没有名字,使用default exchange
        Routing-Key: hello 
        .... ...0 = Mandatory: False
        .... ..0. = Immediate: False

8、Consumers

消费者(consumer)可以通过订阅(Subscribe)的方式或者轮询(Polling)的方式,获得某个队列的消息。轮询的方式不推荐,效率比较低。

每个消费者分配有一个consumer tag

Example:“Hello World” —— Consumer

Packet comments
    生成Consumer-Tag
Frame 18: 130 bytes on wire (1040 bits), 130 bytes captured (1040 bits) on interface docker0, id 0
Ethernet II, Src: receiver (02:42:ac:11:00:04), Dst: rabbitmq (02:42:ac:11:00:02)
Internet Protocol Version 4, Src: receiver (172.17.0.4), Dst: rabbitmq (172.17.0.2)
Transmission Control Protocol, Src Port: 47890, Dst Port: 5672, Seq: 382, Ack: 597, Len: 64
Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 1
    Length: 56
    Class: Basic (60)
    Method: Consume (20)
    Arguments
        Ticket: 0
        Queue: hello
        Consumer-Tag: ctag1.a0f530198eb74e1a85390418796baf1a
        .... ...0 = No-Local: False
        .... ..1. = No-Ack: True
        .... .0.. = Exclusive: False
        .... 0... = Nowait: False
        Filter

8.1 Message Acknowledgements

AMQP 0-9-1 规范允许消费者控制消息确认机制。有两种确认模式:

  1. 在代理(Broker)向应用程序发送消息后(使用 basic.deliver 或 basic.get-ok 方法)。
  2. 在应用程序发送回确认后(使用 basic.ack 方法)。

前者被称为自动确认模型(automatic acknowledgement model),而后者被称为显式确认模型(explicit acknowledgement model)

自动确认模型中,当消息代理将消息发送给应用程序后,如果没有任何错误,消息将自动从队列中删除,无需应用程序显式确认。

显式确认模型中,应用程序选择何时发送确认。它可以在接收到消息后立即发送,或者在将消息持久化到数据库后再进行处理,或者在完全处理完消息后发送(例如,成功获取网页、处理并存储到某个持久化数据库之后)。

Example:“Worker queue” —— 显式确认

1、消费者要求显示确认

Frame 20: 135 bytes on wire (1080 bits), 135 bytes captured (1080 bits) on interface docker0, id 0
Ethernet II, Src: receiver (02:42:ac:11:00:03), Dst: rabbitmq (02:42:ac:11:00:05)
Internet Protocol Version 4, Src: receiver (172.17.0.3), Dst: rabbitmq (172.17.0.5)
Transmission Control Protocol, Src Port: 34932, Dst Port: 5672, Seq: 406, Ack: 614, Len: 69
Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 1
    Length: 61
    Class: Basic (60)
    Method: Consume (20)
    Arguments
        Ticket: 0
        Queue: task_queue
        Consumer-Tag: ctag1.0028a0f65f8645efbcf68f81bdbfd278
        .... ...0 = No-Local: False
        .... ..0. = No-Ack: False
        .... .0.. = Exclusive: False
        .... 0... = Nowait: False
        Filter

2、消费者收到消息后,进行显式确认

Frame 247: 87 bytes on wire (696 bits), 87 bytes captured (696 bits) on interface docker0, id 0
Ethernet II, Src: receiver (02:42:ac:11:00:03), Dst: rabbitmq (02:42:ac:11:00:05)
Internet Protocol Version 4, Src: receiver (172.17.0.3), Dst: rabbitmq (172.17.0.5)
Transmission Control Protocol, Src Port: 34932, Dst Port: 5672, Seq: 475, Ack: 782, Len: 21
Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 1
    Length: 13
    Class: Basic (60)
    Method: Ack (80)
    Arguments
        Delivery-Tag: 1
        .... ...0 = Multiple: False

 8.2 Prefetching Messages

在多个消费者共享一个队列的情况下,能够指定每个消费者在发送下一个确认之前可以一次性接收多少条消息是非常有用的。这可以作为一种简单的负载均衡技术,或者在消息倾向于批量发布时提高吞吐量。例如,如果一个生产者应用程序由于其工作性质每分钟发送一次消息。

需要注意的是,RabbitMQ仅支持在通道级别设置预取计数(prefetch-count),而不是基于连接或基于大小的预取。

Example:“Worker queue” ——prefetch-count

Frame 18: 85 bytes on wire (680 bits), 85 bytes captured (680 bits) on interface docker0, id 0
Ethernet II, Src: receiver (02:42:ac:11:00:03), Dst: rabbitmq (02:42:ac:11:00:05)
Internet Protocol Version 4, Src: receiver (172.17.0.3), Dst: rabbitmq (172.17.0.5)
Transmission Control Protocol, Src Port: 34932, Dst Port: 5672, Seq: 387, Ack: 602, Len: 19
Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 1
    Length: 11
    Class: Basic (60)
    Method: Qos (10)
    Arguments
        Prefetch-Size: 0
        Prefetch-Count: 1
        .... ...0 = Global: False

9、Message Attributes and Payload 

在AMQP 0-9-1模型中,消息具有属性(attributes)。有些属性非常常见,以至于AMQP 0-9-1规范定义了它们,应用程序开发者无需考虑确切的属性名称。一些例子包括:

  • 内容类型(Content type)
  • 内容编码(Content encoding)
  • 路由键(Routing key)
  • 投递模式(Delivery mode),即消息是否持久化
  • 消息优先级(Message priority)
  • 消息发布时间戳(Message publishing timestamp)
  • 消息有效期(Expiration period)
  • 发布应用的ID(Publisher application id)

有些属性由AMQP代理使用,但大多数属性都可以由接收它们的应用程序进行解释。有些属性是可选的,称为头部(headers),它们类似于HTTP中的X-Headers。消息属性在消息发布时设置。

消息还包含一个有效载荷(即它们携带的数据,正文(body)),AMQP代理将其视为不透明的字节数组。代理不会检查或修改有效载荷。消息有可能只包含属性而没有有效载荷。通常使用如JSON、Thrift、Protocol Buffers和MessagePack等序列化格式来序列化结构化数据,以便将其作为消息的有效载荷发布。协议对等方通常使用“content-type”和“content-encoding”字段来传达这些信息,但这仅是基于约定。

Example:“Hello World!”——message组成

Frame 80: 88 bytes on wire (704 bits), 88 bytes captured (704 bits) on interface docker0, id 0
Ethernet II, Src: 02:42:ac:11:00:03 (02:42:ac:11:00:03), Dst: 02:42:ac:11:00:02 (02:42:ac:11:00:02)
Internet Protocol Version 4, Src: 172.17.0.3 (172.17.0.3), Dst: 172.17.0.2 (172.17.0.2)
Transmission Control Protocol, Src Port: 37258, Dst Port: 5672, Seq: 404, Ack: 597, Len: 22
Advanced Message Queuing Protocol
    Type: Content header (2)
    Channel: 1
    Length: 14
    Class ID: Basic (60)
    Weight: 0
    Body size: 12
    Property flags: 0x0000
    Properties

Frame 81: 86 bytes on wire (688 bits), 86 bytes captured (688 bits) on interface docker0, id 0
Ethernet II, Src: 02:42:ac:11:00:03 (02:42:ac:11:00:03), Dst: 02:42:ac:11:00:02 (02:42:ac:11:00:02)
Internet Protocol Version 4, Src: 172.17.0.3 (172.17.0.3), Dst: 172.17.0.2 (172.17.0.2)
Transmission Control Protocol, Src Port: 37258, Dst Port: 5672, Seq: 426, Ack: 597, Len: 20
Advanced Message Queuing Protocol
    Type: Content body (3)
    Channel: 1
    Length: 12
    Payload: 48656c6c6f20576f726c6421 <-- "Hello World!"

10、AMQP 0-9-1 Methods

AMQP 0-9-1 被构建为多种方法(Methods)。方法定义了一系列操作(类似于HTTP方法)。方法又被归为不同的类别(Class)。这些类别只是AMQP方法的逻辑分组。

Example:“Hello World!" —— Basic Methods

1、Basic.Consume

Frame 46: 135 bytes on wire (1080 bits), 135 bytes captured (1080 bits) on interface docker0, id 0
Ethernet II, Src: 02:42:ac:11:00:04, Dst: 02:42:ac:11:00:05
Internet Protocol Version 4, Src: 172.17.0.4, Dst: 172.17.0.5
Transmission Control Protocol, Src Port: 44490, Dst Port: 5672, Seq: 406, Ack: 614, Len: 69
Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 1
    Length: 61
    Class: Basic (60)
    Method: Consume (20)
    Arguments
        Ticket: 0
        Queue: task_queue
        Consumer-Tag: ctag1.9bf1bfaa9e3a499fa3680f0da61e03c6
        .... ...0 = No-Local: False
        .... ..0. = No-Ack: False
        .... .0.. = Exclusive: False
        .... 0... = Nowait: False
        Filter

2、Basic.Publish

Frame 70: 93 bytes on wire (744 bits), 93 bytes captured (744 bits) on interface docker0, id 0
Ethernet II, Src: 02:42:ac:11:00:02, Dst: 02:42:ac:11:00:05
Internet Protocol Version 4, Src: 172.17.0.2, Dst: 172.17.0.5
Transmission Control Protocol, Src Port: 53486, Dst Port: 5672, Seq: 387, Ack: 602, Len: 27
Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 1
    Length: 19
    Class: Basic (60)
    Method: Publish (40)
    Arguments
        Ticket: 0
        Exchange: 
        Routing-Key: task_queue
        .... ...0 = Mandatory: False
        .... ..0. = Immediate: False

3、Basic.Deliver

Frame 75: 183 bytes on wire (1464 bits), 183 bytes captured (1464 bits) on interface docker0, id 0
Ethernet II, Src: 02:42:ac:11:00:05, Dst: 02:42:ac:11:00:03
Internet Protocol Version 4, Src: 172.17.0.5, Dst: 172.17.0.3
Transmission Control Protocol, Src Port: 5672, Dst Port: 34932, Seq: 665, Ack: 475, Len: 117
Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 1
    Length: 64
    Class: Basic (60)
    Method: Deliver (60)
    Arguments
        Consumer-Tag: ctag1.0028a0f65f8645efbcf68f81bdbfd278
        Delivery-Tag: 1
        .... ...0 = Redelivered: False
        Exchange: 
        Routing-Key: task_queue
Advanced Message Queuing Protocol
    Type: Content header (2)
    Channel: 1
    Length: 15
    Class ID: Basic (60)
    Weight: 0
    Body size: 14
    Property flags: 0x1000
    Properties
        Delivery-Mode: 2
Advanced Message Queuing Protocol
    Type: Content body (3)
    Channel: 1
    Length: 14
    Payload: 4669727374206d6573736167652e

11、Connections

AMQP 0-9-1 连接(connection)通常是长期保持的。AMQP 0-9-1 是一个应用层协议,它使用 TCP 来确保消息的可靠传输。连接时使用认证,并可以通过 TLS(SSL)进行保护。当应用程序不再需要与服务器连接时,应该优雅地关闭其 AMQP 0-9-1 连接,而不是突然关闭底层的 TCP 连接。

Example: "Worker queue” —— connection/channel/vhosts

Frame 6: 587 bytes on wire (4696 bits), 587 bytes captured (4696 bits) on interface docker0, id 0
Ethernet II, Src: 02:42:ac:11:00:05, Dst: 02:42:ac:11:00:03
Internet Protocol Version 4, Src: 172.17.0.5, Dst: 172.17.0.3
Transmission Control Protocol, Src Port: 5672, Dst Port: 34932, Seq: 1, Ack: 9, Len: 521
Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 0
    Length: 513
    Class: Connection (10)
    Method: Start (10)
    Arguments
        Version-Major: 0
        Version-Minor: 9
        Server-Properties
            capabilities (field table)
            cluster_name (string): rabbit@b1b73bb557e3
            copyright (string): Copyright (c) 2007-2024 Broadcom Inc and/or its subsidiaries
            information (string): Licensed under the MPL 2.0. Website: https://rabbitmq.com
            platform (string): Erlang/OTP 26.2.5.2
            product (string): RabbitMQ
            version (string): 3.13.6
        Mechanisms: 414d51504c41494e20504c41494e
        Locales: 656e5f5553

 12、Channels

 有些应用程序需要与代理建立多个连接。然而,同时保持许多 TCP 连接是不可取的,因为这样做会消耗系统资源并使配置防火墙变得更加困难。AMQP 0-9-1 通过通道(channel)实现了连接的多路复用,可以将通道视为“共享单个 TCP 连接的轻量级连接”。

客户端执行的每个协议操作都发生在一个通道上。特定通道上的通信与另一个通道上的通信是完全隔离的,因此每个协议方法也携带一个通道 ID(即通道号),代理和客户端都使用这个整数来确定该方法是为哪个通道准备的。

通道只存在于连接的上下文中,而不会单独存在。当连接关闭时,其上的所有通道也会关闭。

Example: "Worker queue” —— connection/channel/vhosts

Frame 14: 79 bytes on wire (632 bits), 79 bytes captured (632 bits) on interface docker0, id 0
Ethernet II, Src: 02:42:ac:11:00:03, Dst: 02:42:ac:11:00:05
Internet Protocol Version 4, Src: 172.17.0.3, Dst: 172.17.0.5
Transmission Control Protocol, Src Port: 34932, Dst Port: 5672, Seq: 344, Ack: 555, Len: 13
Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 1
    Length: 5
    Class: Channel (20)
    Method: Open (10)
    Arguments
        Out-Of-Band: 

13、Virtual Hosts

为了让单个代理能够托管多个隔离的“环境”(用户组、交换器、队列等),AMQP 0-9-1 引入了虚拟主机(vhosts)的概念。它们与许多流行的 Web 服务器使用的虚拟主机类似,为 AMQP 实体提供了完全隔离的环境。协议客户端在连接协商期间指定他们想要使用的虚拟主机。

Example: "Worker queue” —— connection/channel/vhosts

Frame 11: 82 bytes on wire (656 bits), 82 bytes captured (656 bits) on interface docker0, id 0
Ethernet II, Src: 02:42:ac:11:00:03, Dst: 02:42:ac:11:00:05
Internet Protocol Version 4, Src: 172.17.0.3, Dst: 172.17.0.5
Transmission Control Protocol, Src Port: 34932, Dst Port: 5672, Seq: 328, Ack: 542, Len: 16
Advanced Message Queuing Protocol
    Type: Method (1)
    Channel: 0
    Length: 8
    Class: Connection (10)
    Method: Open (40)
    Arguments
        Virtual-Host: /   <--表示连接到根路径,通常用于访问AMQP代理的默认虚拟主机。
        Capabilities: 
        .... ...1 = Insist: True

14、AMQP is Extensible

AMQP 0-9-1是一个高度可扩展的消息队列协议,它提供了多种扩展点来适应不同的应用场景和需求。以下是AMQP 0-9-1的几个关键扩展点:

  1. 自定义exchange类型:开发者可以根据特定的路由需求实现自定义的exchange类型,比如基于地理位置数据的路由,这些是AMQP 0-9-1预设exchange类型无法很好覆盖的。

  2. exchange和queue的声明扩展:在声明exchange和队列时,可以包含额外的属性,这些属性可以被消息代理(如RabbitMQ)使用,例如,RabbitMQ中的每个队列消息的TTL(生存时间)就是通过这种方式实现的。

  3. 代理特定的协议扩展:AMQP 0-9-1允许代理实现特定的协议扩展,例如RabbitMQ实现的一些扩展。

  4. 新方法类的引入:可以引入新的AMQP 0-9-1方法类来支持更多的操作和特性。

  5. 代理的插件扩展:代理可以通过插件进行扩展,例如RabbitMQ的管理前端和HTTP API就是作为插件实现的。

这些扩展点使得AMQP 0-9-1模型非常灵活,能够适应广泛的应用场景和解决各种问题。通过这些扩展,AMQP 0-9-1能够更好地满足不同用户的需求,提高其在多种环境下的适用性和灵活性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2116883.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Day19_0.1基础学习MATLAB学习小技巧总结(19)——MATLAB绘图篇(2)

利用空闲时间把碎片化的MATLAB知识重新系统的学习一遍&#xff0c;为了在这个过程中加深印象&#xff0c;也为了能够有所足迹&#xff0c;我会把自己的学习总结发在专栏中&#xff0c;以便学习交流。 参考书目&#xff1a;《MATLAB基础教程 (第三版) (薛山)》 之前的章节都是…

H5漂流瓶社交系统源码

一个非常有创意的H5漂流瓶社交系统源码&#xff0c;带完整前端h5和后台管理系统。 环境&#xff1a;Nginx 1.20.1-MySQL 5.6.50-PHP-7.3 代码下载

python简单计算入门教程|加减法

python通过调用numpy模块&#xff0c;非常擅长数学计算。再通过调用matplotlib模块&#xff0c;可以自由自在地输出numpy计算的结果。 今天&#xff0c;我们就尝试一些基本计算。 下述是正弦函数和余弦函数的加法和减法计算结果。 图1 代码为&#xff1a; import matplotli…

【stata】处理城市名和城市代码

写了两个简单的外部命令&#xff0c;在这里分享一下&#xff0c;希望能帮到大家 1.citycode_mutate 第一个命令是citycode_mutate&#xff0c;用于识别字符串中可能存在的城市信息&#xff0c;并生成城市代码&#xff08;图1图2&#xff09;。 2.cityname_mutate 第二个命令…

如何编写Linux PCIe设备驱动器 之二

如何编写Linux PCIe设备驱动器 之二 功能(capability)集功能(capability)APIs通过pci_bus_read_config完成功能存取功能APIs参数pos常量值PCI功能结构 PCI功能IDMSI功能电源功率管理功能 功能(capability)集 功能(capability)APIs int pcie_capability_read_word(struct pci_…

C++(一)----C++基础

1.C的发展史 C语言诞生后&#xff0c;很快普及使用&#xff0c;但是随着编程规模增大且越来越复杂&#xff0c;并且需要高度的抽象和建模时&#xff0c;C语言的诸多短板便表现了出来&#xff0c;为了解决软件危机&#xff0c;上世纪八十年代&#xff0c;计算机界提出了oop&…

拓扑排序-广度优先遍历思路

本质&#xff1a; 【广度优先遍历 】【贪心算法】应用于【有向图】的专有名词 应用场景&#xff1a;任务调度&#xff0c;课程安排 作用&#xff1a; 得到一个不唯一的【拓扑序】检测【有向图】是否有环&#xff0c;使用数据【并查集】 使用&#xff1a;先找度为0的前驱节点…

Linux运维排查常见故障_在tmp目录下有大量包含picture_ 的临时文件,每天晚上2 30需要对一天前的文件进行

echo“”>>/etc/security/limits.conf echo“*softnproc65535″>>/etc/security/limits.conf echo“*hardnproc65535″>>/etc/security/limits.conf echo“*softnofile65535″>>/etc/security/limits.conf echo“*hardnofile65535″>>/etc/secur…

【自动驾驶】控制算法(八)横向控制Ⅲ | 代码与模型

写在前面&#xff1a; &#x1f31f; 欢迎光临 清流君 的博客小天地&#xff0c;这里是我分享技术与心得的温馨角落。&#x1f4dd; 个人主页&#xff1a;清流君_CSDN博客&#xff0c;期待与您一同探索 移动机器人 领域的无限可能。 &#x1f50d; 本文系 清流君 原创之作&…

以太网--TCP/IP协议(一)

概述 以太网是局域网的一种&#xff0c;其他的比如还有令牌环、FDDI。和局域网对应的就是广域网&#xff0c;如Internet&#xff0c;城域网等。 从网络层次看&#xff0c;局域网协议主要偏重于低层&#xff08;业内一般把物理层、数据链路层归为低层&#xff09;。以太网协议…

单片机毕业设计基于单片机的智能门禁系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍程序代码部分参考 设计清单具体实现截图参考文献设计获取 前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师&#xff0c;一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP…

vue动态统计图的绘画

效果图&#xff1a; 实现&#xff1a; 一、导入依赖 import echarts from echarts 二、vue的代码实现 1.在main.js导入文件 // 引入 echarts 插件 import echarts from echarts // 配置成全局组件 Vue.prototype.$echarts echarts2.代码实现 <template><!--为echa…

韩国火烧车影响出现,浙江出现限制电车进入地下车库,车主难受了

韩国电动汽车起火&#xff0c;烧毁140辆汽车&#xff0c;还导致大楼损坏以及居民受伤的后果&#xff0c;如今在中国市场也产生了影响&#xff0c;《华商报》旗下的《大风新闻》报道指&#xff0c;浙江多地的饭店、大厦禁止电动汽车进入地下车库&#xff0c;这下子电动汽车车主又…

滑动窗口在算法中的应用

滑动窗口是一种经典的算法技巧&#xff0c;就像在处理一系列动态数据时&#xff0c;用一扇可以滑动的“窗口”来捕捉一段连续的子数组或子字符串。通过不断地移动窗口的起点或终点&#xff0c;我们能够以较低的时间复杂度来解决一系列问题。在这篇文章中&#xff0c;我们将通过…

图形视频处理软件Adobe After Effects(AE)2024WIN/MAC下载及系统要求

目录 一、Adobe AE软件简介 1.1 什么是Adobe AE软件 1.2 AE软件的发展历程 1.3 AE软件的应用领域 二、Adobe AE软件下载 2.1 下载 2.2 下载注意事项 三、Adobe AE软件系统要求 3.1 最低配置要求 3.2 推荐配置要求 3.3 显示器和分辨率 四、Adobe AE软件安装与使用 …

【MacOS】mac定位服务中删除已经卸载的软件

mac定位服务中删除已经卸载的软件 网上的帖子真不靠谱 直接右键 WeTypeSettings &#xff0c;查找位置&#xff0c;丢废纸篓即可&#xff01;会提示你卸载的&#xff01;

Pyramid: Real-Time LoRa Collision Decoding with Peak Tracking技术思考与解读

一点点个人的论文解读、技术理解&#xff0c;难免会有错误&#xff0c;欢迎大家一起交流和学习~~ &#x1f600;作者关于lora的系列文章从问题陈述到方法论的提出&#xff0c;再到实验评估&#xff0c;文章结构条理清晰&#xff0c;逻辑性强&#xff0c;并深入分析了LoRa信号处…

力扣刷题(5)

整数转罗马数字 整数转罗马数字-力扣 思路&#xff1a; 把各十百千位可能出现的情况都列出来&#xff0c;写成一个二维数组找出该数的各十百千位&#xff0c;与数组中的罗马元素对应 const char* ch[4][10]{{"", "I", "II", "III"…

webpack - 五大核心概念和基本配置(打包一个简单HTML页面)

// 五大核心概念 1. entry&#xff08;入口&#xff09; 指示Webpack从哪个文件开始打包2. output&#xff08;输出&#xff09; 指示Webpack打包完的文件输出到哪里去&#xff0c;如何命名等3. loader&#xff08;加载器&#xff09; webpack本身只能处理js&#xff0c;json等…

Bev pool 加速(2):自定义c++扩展

文章目录 1. c++扩展2. 案例2.1 案例12. 1.1 代码实现(1) c++ 文件(2) setup.py编写(3) python 代码编写2.1 案例1在bevfusion论文中,将bev_pooling定义为view transform中的效率瓶颈,bevfusion 主要就是对bev_pooling进行了加速,使得视图转换的速度提高了40倍,延迟从500ms…