AMQP與QPID簡介

來源:互聯網
上載者:User

自已整理的一些零散的知識點

簡介

AMQP(訊息佇列協議,Advanced Message Queuing Protocol)是一種訊息協議 ,等同於JMS,但是JMS只是java平台的方案,AMQP是一個跨語言的協議。

AMQP 不分語言平台,最初來自JPMorgon,因為業務需要而滋生,很快從金融界推廣到整個電腦界流行起來。

AMQP 目前還是一個草案,最新版本是:0.10


Publisher --->Exchange ---> MessageQueue --->Consumer

整個過程是非同步.Publisher,Consumer相互不知道對方的存在

Exchange負責交換/路由,依靠Routing Key,每個訊息者有一個Routing Key

每個Binding將自已感興趣的RoutingKey告訴Exchange,以便Exchange將相關的

訊息轉寄給相應的Queue


幾個概念

Producer,Routing Key,Exchange,Binding,Queue,Consumer.

Producer: 訊息的建立者,訊息的寄件者

Routing Key:唯一用來映射訊息該進入哪個隊列的標識

Exchange:負責訊息的路由,交換

Binding:定義Queue和Exchange的映射關係

Queue:訊息佇列

Consumer:訊息的使用者


Exchange類型

Fan-Out:類似於廣播方式,不管RoutingKey

Direct:根據RoutingKey,進行關聯投寄 

Topic:類似於Direct,但是支援多個Key關聯,以組的方式投寄。

      key以.來定義界限。類似於usea.news,usea.weather.這兩個訊息是一組的。


QPID

QPID是AMQP的一個實現,提供C++,JAVA版本的broker,支援多種語言用戶端。

準系統外提供以下特性:

採用 Corosync(?)來保證叢集環境下的Fault-tolerant(?) 特性

支援XML的Exchange,訊息為XML時,彩用Xquery過濾

支援plugin

提供安全認證,可對producer/consumer提供身份認證

qpidd --port --no-data-dir --auth

port:連接埠

--no-data-dir:不指定資料目錄

--auth:不啟用安全身份認證


啟動後自動建立一些Exchange,amp.topic,amp.direct,amp.fanout

tools:

Qpid-config:維護Queue,Exchange,內部配置 

Qpid-route:配置broker Federation(聯盟?叢集?)

Qpid-tool:監控

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.