首頁 後端開發 php教程 RabbitMQ與PHP(一)- RabbitMQ的原理與操作範例

RabbitMQ與PHP(一)- RabbitMQ的原理與操作範例

Aug 08, 2016 am 09:29 AM
channel gt key nbsp

RabbitMQ是流行的開源訊息佇列系統,用erlang語言開發,完整的實作了AMQP(高階訊息佇列協定)。網站在: http://www.rabbitmq.com/  上面有教學和實例程式碼(Python和Java的)。
7af40ad162d9f2d36b6bf89fa8ec8a136327cc4c
AMPQ協定為了能夠滿足各種訊息佇列需求,在概念上比較複雜。首先,rabbitMQ啟動預設是沒有任何設定的,需要客戶端連線上去,設定交換器等才能運作。不把這些基礎概念弄清楚,後面程式設計就容易產生問題。
1.vhosts : 虛擬主機。
一個RabbitMQ的實體上可以有多個vhosts,使用者與權限設定就是依附在vhosts。對一般PHP應用,不需要使用者權限設定,直接使用預設就存在的"/"就可以了,使用者可以使用預設就存在的"guest"。一個簡單的設定範例:
$conn_args = array(
    'host' => '127.0.0.1',
    'port' => '5672',
 o. 'guest',
    'vhost'=>'/'
);
2.connection 與channel :  連接與通道
connection是指物理的連接,一個client與一個server之間有一個連接;一個連接上可以建立多個channel,可以理解為邏輯上的連結。一般應用的情況下,有一個channel就夠用了,不需要創造更多的channel。範例程式碼:
//建立連線和channel
$conn = new AMQPConnection($conn_args);
if (!$conn->connect()) {
    die("Cannot connect to the broker!n");
}
$channel = new AMQPChannel($conn);
3.exchange 與  routingkey : 交換器與路由鍵
為了將不同類型的訊息區分,設定了交換器與路由兩個概念。例如,將A類型的消息傳送到名為‘C1’的交換機,將類型為B的發送到'C2'的交換機。當客戶端連接C1處理佇列訊息時,取到的就只是A類型訊息。進一步的,如果A類型訊息也非常多,需要進一步細化區分,例如某個客戶端只處理A類型訊息中針對K用戶的訊息,routingkey就是來做這個用途的。
$e_name = 'e_linvo'; //交換器名稱
$k_route = array(0=> 'key_1', 1=> 'key_2'); //路由key
//建立交換器
$ex = new AMQPExchange($ channel);
$ex->setName($e_name);
$ex->setType(AMQP_EX_TYPE_DIRECT); //direct類型
$ex->setFlags(AMQP_DURABLE); //持久化
echo "Exchange:". $ex->declare()."n";
for($i=0; $i    echo "Send Message:".$ex->publish($message . date( 'H:i:s'), $k_route[i%2])."n";
}
由以上代碼可以看到,發送訊息時,只要有「交換器」就夠了。至於交換器後面有沒有對應的處理佇列,發送方是不用管的。 routingkey可以是空的字串。在範例中,我使用了兩個key交替發送訊息,是為了下面更方便理解routingkey的作用。
對於交換機,有兩個重要的概念:
A,類型。有三種類型: Fanout類型最簡單,這種模型忽略routingkey;Direct類型是使用最多的,使用確定的routingkey。這種模型下,接收訊息時綁定'key_1'則只接收key_1的訊息;最後一種是Topic,這種模式與Direct類似,但是支援通配符進行匹配,例如: 'key_*',就會接受key_1和key_2。 Topic看起來像美好,但有可能導致不嚴謹,所以還是推薦使用Direct。
B,持久化。指定了持久化的交換機,在重新啟動時才能重建,否則需要客戶端重新聲明產生才行。
需要特別明確的概念:交換器的持久化,並不等於訊息的持久化。只有在持久化佇列中的消息,才能持久化;如果沒有佇列,訊息是沒有地方儲存的;訊息本身在投遞時也有一個持久化標誌的,PHP中預設投遞到持久化交換器就是持久的訊息,不用特別指定。
4.queue: 隊列
講了這麼多,才講到隊列呀。事實上,佇列僅是針對接收方(consumer)的,由接收者根據需求創建的。只有佇列建立了,交換器才會將新接受到的訊息送到佇列中,交換器是不會在佇列建立之前的訊息放進來的。換句話說,在建立佇列之前,發出的所有訊息都被丟棄了。下面這個圖比RabbitMQ官方的圖更清楚──Queue是屬於ReceiveMessage的一部分。
024f78f0f736afc37053e415b219ebc4b7451266
接下來看一下建立佇列及接收訊息的範例:
$e_name = 'e_linvo'; //交換器名稱編號
//建立連線與channel
$conn = new AMQPConnection($conn_args);
if (!$conn->connect()) {
    die("Cannot connect to the broker!n");
}
$channel = new AMQPChannel($conn);
//建立交換器
$ex = new AMQPExchange($channel);
$ex->setName($e_name);
$ex->setType(AMQP_EX_TYPE_DIRECT); //directECT);類型
$ex->setFlags(AMQP_DURABLE); //持久化
echo "Exchange Status:".$ex->declare()."n";
//建立佇列
$q = new AMQPQueue($channel) ;
$q->setName($q_name);
$q->setFlags(AMQP_DURABLE); //持久化
//綁定交換器與佇列,並指定路由鍵
echo 'Queue Bind: '.$q- >bind($e_name, $k_route)."n";
//阻塞模式接收訊息
echo "Message:n";
$q->consume('processMessage', AMQP_AUTOACK); //自動答應$
ACK$ conn->disconnect();
/**
* 消費回呼函數
* 處理訊息
*/
function processMessage($envelope, $queue) {
    var_dump($envelope->getRoutingKey);
  echo $msg."n"; //處理訊息
}
從上述範例可以看到,交換器既可以由訊息傳送端創建,也可以由訊息消費者建立。
建立一個佇列(line:20)後,需要將佇列綁定到交換器上(line:25)佇列才能運作,routingkey也是在這裡指定的。有的資料上寫成bindingkey,其實一回事兒,弄兩個名詞反倒容易混淆。
訊息的處理,有兩種方式:
A,一次性。用 $q->get([...]),不管拿不到訊息都會立即返回,一般情況下使用輪詢處理訊息佇列就要用這種方式;
B,阻塞。用 $q->consum( callback, [...] ) 程式會進入持續偵聽狀態,每收到一個訊息就會呼叫callback指定的函數一次,直到某個callback函數回傳FALSE才結束。
關於callback,這裡多說幾句: PHP的call_back是支援使用陣列的,例如: $c = new MyClass(); $c->counter = 100; $q->consume( array($c,'myfunc ') ) 這樣就可以呼叫自己寫的處理類別。 MyClass中myfunc的參數定義,與上例中processMessage一樣就行。
在上述範例中,使用的$routingkey = '', 意味著接收全部的訊息。我們可以將其改為 $routingkey = 'key_1',可以看到結果中僅有設定routingkey為key_1的內容了。
注意: routingkey = 'key_1'  與 routingkey = 'key_2' 是兩個不同的佇列。假設: client1 與 client2 都連接到 key_1 的佇列上,一個訊息被client1處理之後,就不會被client2處理。而 routingkey = '' 是另類,client_all綁定到 '' 上,將訊息全都處理後,client1和client2上也就沒有消息了。
在程式設計上,需要規劃好exchange的名稱,以及如何使用key區分開不同類型的標記,在訊息產生的地方插入發送訊息代碼。後端處理,可以針對每一個key啟動一個或多個client,以提高訊息處理的即時性。如何使用PHP進行多執行緒的訊息處理,將在下一節中講述。
更多訊息模型,可參考:http://www.rabbitmq.com/tutorials/tutorial-two-python.html
b03533fa828ba61e15fc0e5f4034970a304e59b4
http://nonfu.
以上就介紹了RabbitMQ與PHP(一)- RabbitMQ的原理與操作範例,包括了方面的內容,希望對PHP教學有興趣的朋友有所幫助。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1421
52
Laravel 教程
1315
25
PHP教程
1266
29
C# 教程
1239
24
解決方法:您的組織要求您更改 PIN 碼 解決方法:您的組織要求您更改 PIN 碼 Oct 04, 2023 pm 05:45 PM

「你的組織要求你更改PIN訊息」將顯示在登入畫面上。當在使用基於組織的帳戶設定的電腦上達到PIN過期限制時,就會發生這種情況,在該電腦上,他們可以控制個人設備。但是,如果您使用個人帳戶設定了Windows,則理想情況下不應顯示錯誤訊息。雖然情況並非總是如此。大多數遇到錯誤的使用者使用個人帳戶報告。為什麼我的組織要求我在Windows11上更改我的PIN?可能是您的帳戶與組織相關聯,您的主要方法應該是驗證這一點。聯絡網域管理員會有所幫助!此外,配置錯誤的本機原則設定或不正確的登錄項目也可能導致錯誤。即

Windows 11 上調整視窗邊框設定的方法:變更顏色和大小 Windows 11 上調整視窗邊框設定的方法:變更顏色和大小 Sep 22, 2023 am 11:37 AM

Windows11將清新優雅的設計帶到了最前沿;現代介面可讓您個性化和更改最精細的細節,例如視窗邊框。在本指南中,我們將討論逐步說明,以協助您在Windows作業系統中建立反映您的風格的環境。如何更改視窗邊框設定?按+開啟“設定”應用程式。 WindowsI前往個人化,然後按一下顏色設定。顏色變更視窗邊框設定視窗11「寬度=」643「高度=」500「>找到在標題列和視窗邊框上顯示強調色選項,然後切換它旁邊的開關。若要在「開始」功能表和工作列上顯示主題色,請開啟「在開始」功能表和工作列上顯示主題

如何在 Windows 11 上變更標題列顏色? 如何在 Windows 11 上變更標題列顏色? Sep 14, 2023 pm 03:33 PM

預設情況下,Windows11上的標題列顏色取決於您選擇的深色/淺色主題。但是,您可以將其變更為所需的任何顏色。在本指南中,我們將討論三種方法的逐步說明,以更改它並個性化您的桌面體驗,使其具有視覺吸引力。是否可以更改活動和非活動視窗的標題列顏色?是的,您可以使用「設定」套用變更活動視窗的標題列顏色,也可以使用登錄編輯程式變更非活動視窗的標題列顏色。若要了解這些步驟,請前往下一部分。如何在Windows11中變更標題列的顏色? 1.使用「設定」應用程式按+開啟設定視窗。 WindowsI前往“個人化”,然

Windows 11 上啟用或停用工作列縮圖預覽的方法 Windows 11 上啟用或停用工作列縮圖預覽的方法 Sep 15, 2023 pm 03:57 PM

工作列縮圖可能很有趣,但它們也可能分散注意力或煩人。考慮到您將滑鼠懸停在該區域的頻率,您可能無意中關閉了重要視窗幾次。另一個缺點是它使用更多的系統資源,因此,如果您一直在尋找一種提高資源效率的方法,我們將向您展示如何停用它。不過,如果您的硬體規格可以處理它並且您喜歡預覽版,則可以啟用它。如何在Windows11中啟用工作列縮圖預覽? 1.使用「設定」應用程式點擊鍵並點選設定。 Windows按一下系統,然後選擇關於。點選高級系統設定。導航至“進階”選項卡,然後選擇“效能”下的“設定”。在「視覺效果」選

OOBELANGUAGE錯誤Windows 11 / 10修復中出現問題的問題 OOBELANGUAGE錯誤Windows 11 / 10修復中出現問題的問題 Jul 16, 2023 pm 03:29 PM

您是否在Windows安裝程式頁面上看到「出現問題」以及「OOBELANGUAGE」語句? Windows的安裝有時會因此類錯誤而停止。 OOBE表示開箱即用的體驗。正如錯誤提示所表示的那樣,這是與OOBE語言選擇相關的問題。沒有什麼好擔心的,你可以透過OOBE螢幕本身的漂亮註冊表編輯來解決這個問題。快速修復–1.點選OOBE應用底部的「重試」按鈕。這將繼續進行該過程,而不會再打嗝。 2.使用電源按鈕強制關閉系統。系統重新啟動後,OOBE應繼續。 3.斷開系統與網際網路的連接。在脫機模式下完成OOBE的所

Windows 11 上的顯示縮放比例調整指南 Windows 11 上的顯示縮放比例調整指南 Sep 19, 2023 pm 06:45 PM

在Windows11上的顯示縮放方面,我們都有不同的偏好。有些人喜歡大圖標,有些人喜歡小圖標。但是,我們都同意擁有正確的縮放比例很重要。字體縮放不良或圖像過度縮放可能是工作時真正的生產力殺手,因此您需要知道如何自訂以充分利用系統功能。自訂縮放的優點:對於難以閱讀螢幕上的文字的人來說,這是一個有用的功能。它可以幫助您一次在螢幕上查看更多內容。您可以建立僅適用於某些監視器和應用程式的自訂擴充功能設定檔。可以幫助提高低階硬體的效能。它使您可以更好地控制螢幕上的內容。如何在Windows11

10種在 Windows 11 上調整亮度的方法 10種在 Windows 11 上調整亮度的方法 Dec 18, 2023 pm 02:21 PM

螢幕亮度是使用現代計算設備不可或缺的一部分,尤其是當您長時間注視螢幕時。它可以幫助您減輕眼睛疲勞,提高易讀性,並輕鬆有效地查看內容。但是,根據您的設置,有時很難管理亮度,尤其是在具有新UI更改的Windows11上。如果您在調整亮度時遇到問題,以下是在Windows11上管理亮度的所有方法。如何在Windows11上變更亮度[10種方式解釋]單一顯示器使用者可以使用下列方法在Windows11上調整亮度。這包括使用單一顯示器的桌上型電腦系統以及筆記型電腦。讓我們開始吧。方法1:使用操作中心操作中心是訪問

華為GT3 Pro和GT4的差異是什麼? 華為GT3 Pro和GT4的差異是什麼? Dec 29, 2023 pm 02:27 PM

許多用戶在選擇智慧型手錶的時候都會選擇的華為的品牌,其中華為GT3pro和GT4都是非常熱門的選擇,不少用戶都很好奇華為GT3pro和GT4有什麼區別,下面就給大家介紹一下二者。華為GT3pro和GT4有什麼差別一、外觀GT4:46mm和41mm,材質是玻璃鏡板+不鏽鋼機身+高分纖維後殼。 GT3pro:46.6mm和42.9mm,材質是藍寶石玻璃鏡+鈦金屬機身/陶瓷機身+陶瓷後殼二、健康GT4:採用最新的華為Truseen5.5+演算法,結果會更加的精準。 GT3pro:多了ECG心電圖和血管及安

See all articles