企業級PHP異步RabbitMQ協程版客戶端 2.0 正式發布

概述

workerman/rabbitmq 是一個異步RabbitMQ客戶端,使用AMQP協議。

RabbitMQ是一個基于AMQP(高級消息隊列協議)實現的開源消息組件,它主要用于在分布式系統中存儲和轉發消息。RabbitMQ由高性能、高可用以及高擴展性出名的Erlang語言寫成,具有高度的可靠性和可擴展性。它支持多種消息協議,包括AMQP、STOMP、MQTT等,并廣泛應用于消息隊列、消息中間件等領域。

RabbitMQ允許應用程序通過消息傳遞進行通信,這使得不同的應用程序可以在不同的語言和操作系統之間進行通信。

RabbitMQ的消息工作機制涉及消息從發送端到接收端的流轉過程。在這個過程中,消息首先被發送到交換機(Exchange),然后交換機根據路由規則將消息路由到一個或多個隊列(Queue)中。消費者(Consumer)從隊列中獲取消息并進行處理。

生產者和消費者

安裝

composer?require?workerman/rabbitmq

消費者

receive.php

<?phpdeclare(strict_types=1);use?Bunny\Channel;
use?Bunny\Message;
use?Workerman\Worker;
use?Workerman\RabbitMQ\Client;require_once?__DIR__?.?'/vendor/autoload.php';$worker?=?new?Worker();
$worker->eventLoop?=?\Workerman\Events\Revolt::class;$worker->onWorkerStart?=?function()?{//?Create?RabbitMQ?Client$client?=?Client::factory(['host'?=>?'127.0.0.1','port'?=>?5672,'user'?=>?'guest','password'?=>?'guest','vhost'?=>?'/','heartbeat'?=>?60,'heartbeat_callback'?=>?function?()?{echo?"?[-]?coroutine-consumer-heartbeat\n";},'interval'?=>?[100,?300]])->connect();$channel?=?$client->channel();$channel->queueDeclare('hello-coroutine');//?Consumer$channel->consume(function?(Message?$message,?Channel?$channel,?\Bunny\AbstractClient?$client)?{echo?"?[>]?Received?",?$message->content,?"\n";},'hello-coroutine','',false,true);$client->run();echo?'?[*]?Waiting?for?messages.?To?exit?press?CTRL+C',?"\n";//?Producer\Workerman\Timer::add($interval?=?5?,?function?()?use?($channel)?{$channel->publish($message?=?'Hello?World?By?Self?Timer.?'?.?time(),?[],?'',?'hello-coroutine');echo?"?[<]?Sent?$message\n";});echo?"?[!]?Producer?timer?created,?interval:?$interval?s.\n";};
Worker::runAll();

運行命令

php?receive.php?start

基于 Workerman 發布

send.php

<?phpdeclare(strict_types=1);use?Workerman\RabbitMQ\Client;
use?Workerman\Worker;require_once?__DIR__?.?'/vendor/autoload.php';$worker?=?new?Worker();
$worker->eventLoop?=?\Workerman\Events\Revolt::class;$worker->onWorkerStart?=?function()?{$client?=?Client::factory(['host'?=>?'host.docker.internal','port'?=>?5672,'user'?=>?'guest','password'?=>?'guest','vhost'?=>?'/','heartbeat'?=>?60,'heartbeat_callback'?=>?function?()?{echo?"coroutine-producer-heartbeat\n";}])->connect();$channel?=?$client->channel();$channel->queueDeclare('hello-coroutine');//?每5秒發一個消息\Workerman\Timer::add(5,?function?()?use?($channel)?{$channel->publish($message?=?'Hello?World?By?Workerman?Env?Producer.?'?.?time(),?[],?'',?'hello-coroutine');echo?"?[x]?Sent?'$message'\n";});
};
Worker::runAll();

運行命令

php?send.php?start

基于 PHP-FPM 發布

script.php

<?phpdeclare(strict_types=1);use?Workerman\RabbitMQ\Client;require_once?__DIR__?.?'/vendor/autoload.php';$client?=?Client::factory(['host'?=>?'host.docker.internal','port'?=>?5672,'user'?=>?'guest','password'?=>?'guest','vhost'?=>?'/','heartbeat'?=>?60,'heartbeat_callback'?=>?function?()?{echo?"coroutine-producer-heartbeat\n";}
])->connect();
$channel?=?$client->channel();
$channel->queueDeclare('hello-coroutine');
$res?=?$channel->publish($message?=?'Hello?World?By?Normal?Producer.?'?.?time(),?[],?'',?'hello-coroutine');echo?"?[x]?Sent?'$message',?success:?$res\n";

運行命令

php?script.php

異步消費者

receive.php

<?phpuse?Bunny\Channel;
use?Bunny\Message;
use?Workerman\Worker;
use?Workerman\RabbitMQ\Client;require?__DIR__?.?'/vendor/autoload.php';$worker?=?new?Worker();$worker->onWorkerStart?=?function()?{(new?Client())->connect()->then(function?(Client?$client)?{return?$client->channel();})->then(function?(Channel?$channel)?{return?$channel->queueDeclare('hello',?false,?false,?false,?false)->then(function?()?use?($channel)?{return?$channel;});})->then(function?(Channel?$channel)?{echo?'?[*]?Waiting?for?messages.?To?exit?press?CTRL+C',?"\n";$channel->consume(function?(Message?$message,?Channel?$channel,?Client?$client)?{echo?"?[x]?Received?",?$message->content,?"\n";},'hello','',false,true);});
};
Worker::runAll();

運行命令

php?receive.php?start

異步生產者

send.php

<?php
use?Bunny\Channel;
use?Bunny\Message;
use?Workerman\Worker;
use?Workerman\RabbitMQ\Client;require?__DIR__?.?'/vendor/autoload.php';$worker?=?new?Worker();$worker->onWorkerStart?=?function()?{(new?Client())->connect()->then(function?(Client?$client)?{return?$client->channel();})->then(function?(Channel?$channel)?{return?$channel->queueDeclare('hello',?false,?false,?false,?false)->then(function?()?use?($channel)?{return?$channel;});})->then(function?(Channel?$channel)?{echo?"?[x]?Sending?'Hello?World!'\n";return?$channel->publish('Hello?World!',?[],?'',?'hello')->then(function?()?use?($channel)?{return?$channel;});})->then(function?(Channel?$channel)?{echo?"?[x]?Sent?'Hello?World!'\n";$client?=?$channel->getClient();return?$channel->close()->then(function?()?use?($client)?{return?$client;});})->then(function?(Client?$client)?{$client->disconnect();});
};
Worker::runAll();

運行命令

php?send.php?start

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/65731.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/65731.shtml
英文地址,請注明出處:http://en.pswp.cn/web/65731.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

AsyncOperation.allowSceneActivation導致異步加載卡死

先看這段代碼&#xff0c;有個詭異的問題&#xff0c;不確定是不是bug public class Test : MonoBehaviour {void Start(){StartCoroutine(LoadScene(Ego.LoadingLevel));}IEnumerator LoadScene(string sceneName){LoadingUI.UpdateProgress(0.9f);yield return new WaitForS…

C#使用MVC框架創建WebApi服務接口

第一步,使用VS2019新建MVC-Web API應用程序 創建BridgeApi 第二步,運行將生成默認的示例網頁,網頁Url為 https://localhost:44361/home/index 右鍵 項目 添加 WebAPI控制器類 添加 我們可以看到App_Start目錄下 有三個文件: BundleConfig.cs代表 捆綁文件的引用 有腳本文件…

wordpress 房產網站篩選功能

自定義分類法創建 add_action( init, ashu_post_type ); function ashu_post_type() {register_taxonomy(province,post,array(label => 省,rewrite => array( slug => province ),hierarchical => true));register_taxonomy(city,post,array(label => 市,rewr…

hive遷移后修復分區慢,怎么辦?

我有1個30TB的分區表&#xff0c;客戶給的帶寬只有600MB&#xff0c;按照150%的耗時來算&#xff0c;大概要遷移17小時。 使用hive自帶的修復分區命令&#xff08;一般修復分區比遷移時間長一點&#xff09;&#xff0c;可能要花24小時。于是打算用前面黃大佬的牛B方案。 Hive增…

慧集通(DataLinkX)iPaaS集成平臺-業務建模之業務對象(一)

通過左側導航菜單〖業務建模〗→〖業務對象〗&#xff0c;進入該界面&#xff1b;在該界面可以查看到系統中已存在的業務對象&#xff1b; 1.新建業務對象 在DatalinkX中進入【業務建模】的【業務對象】頁面&#xff0c;點擊【新建】按鈕進入新建頁面&#xff1b; 新建頁面左側…

Linux系統之hostname相關命令基本使用

Linux系統之hostname相關命令基本使用 一、檢查本地系統版本二、hostname命令的幫助說明中文幫助說明 三、hostname命令的基本使用1. 查看計算機名2. 查看本機上所有IP地址3. 查看主機FQDN4. 查看短主機名 四、hostnamectl命令的使用1. 查看主機詳細信息2. 設置主機名3. hostna…

DC系列靶場滲透--DC-3

目錄 環境搭建 開始滲透 掃存活 掃端口 掃服務 查看80端口 嘗試在80端口中的登陸頁面尋找sql注入失敗 掃目錄 進入/htaccess.txt目錄看一下 我們嘗試找一下Joomla3.7.0版本的漏洞 我們嘗試利用該漏洞 查數據庫名 查表名 查列名 查數據 找到密碼的可能的編碼方式…

js代理模式

允許在不改變原始對象的情況下&#xff0c;通過代理對象來訪問原始對象。代理對象可以在訪問原始對象之前或之后&#xff0c;添加一些額外的邏輯或功能。 科學上網過程 一般情況下,在訪問國外的網站,會顯示無法訪問 因為在dns解析過程,這些ip被禁止解析,所以顯示無法訪問 引…

uniapp 之 uni-forms校驗提示【提交的字段[‘xxx‘]在數據庫中并不存在】解決方案

目錄 場景問題代碼結果問題剖析解決方案 場景 uni-forms官方組件地址 使用uniapp官方提供的組件&#xff0c;某個表單需求&#xff0c;單位性質字段如果是高校&#xff0c;那么工作單位則是高校的下拉選擇格式&#xff0c;單位性質如果是其他的類型&#xff0c;工作單位則是手動…

深度學習知識點:RNN

文章目錄 1.簡單介紹2.網絡結構3.應對梯度消失 1.簡單介紹 循環神經網絡&#xff08;RNN&#xff0c;Recurrent Neural Network&#xff09;是一類用于處理序列數據的神經網絡。與傳統網絡相比&#xff0c;變化不是特別大&#xff0c;不如CNN的變化那么大。 為什么要有循環神經…

(leetcode算法題)287. 尋找重復數(經典題目,二分解法)

如果一個題目限定了數據范圍是[1, n]內的整數&#xff0c;那么這個題目可以思考的就是 nums[i]和 i 的關系&#xff0c;769. 最多能完成排序的塊 這個題就使用到了子數組中最大值和 連續[0, n - 1]的關系 而對于本題來說&#xff0c;也可以思考[1, n] 和 nums[i] 的關系&…

獲得PostgreSQL中級認證后,可以從事哪些工作崗位?

獲得 PostgreSQL 中級認證后&#xff0c;可以獲得的崗位 數據庫管理類 數據庫管理員&#xff08;DBA&#xff09;&#xff1a;負責 PostgreSQL 數據庫的日常維護、監控、備份與恢復、性能優化、安全管理等工作。確保數據庫的穩定運行和數據的安全性、完整性&#xff0c;及時處理…

4.1、二纖單向、二纖雙向、四纖雙向,網絡級保護

1、線性復用段保護&#xff08;LMSP&#xff09; 就像是給網絡業務傳輸準備的一個 “保險”。在 SDH 和 MSTP 網絡里&#xff0c;業務信號要通過一段一段的路&#xff08;復用段&#xff09;來傳輸&#xff0c;LMSP 就是為了保證這些路出問題的時候&#xff0c;業務還能正常走。…

【spark源碼修改】hive3.1.3 spark3.5.4編譯,需要修改源碼,最終編譯成功

【spark源碼修改】hive3.1.3 spark3.5.4編譯,需要修改源碼,最終編譯成功 1. 準備安裝包與maven編譯環境1.1 安裝環境準備1.2 修改pom1.3 打包命令2. 編譯與問題解決2.1 開始編譯 失敗, 缺包pentaho-aggdesigner-algorithm:pom:5.1.5-jhyde2.2 Hive Spark Remote Client 模塊…

SQL-leetcode-584. 尋找用戶推薦人

584. 尋找用戶推薦人 表: Customer -------------------- | Column Name | Type | -------------------- | id | int | | name | varchar | | referee_id | int | -------------------- 在 SQL 中&#xff0c;id 是該表的主鍵列。 該表的每一行表示一個客戶的 id、姓名以及推…

【數據庫】一、數據庫系統概述

文章目錄 一、數據庫系統概述1 基本概念2 現實世界的信息化過程3 數據庫系統內部體系結構4 數據庫系統外部體系結構5 數據管理方式 一、數據庫系統概述 1 基本概念 數據&#xff1a;描述事物的符號記錄 數據庫&#xff08;DB&#xff09;&#xff1a;長期存儲在計算機內的、…

Scala語言的面向對象編程

Scala語言的面向對象編程 面向對象編程&#xff08;Object-Oriented Programming&#xff0c;OOP&#xff09;是一種編程范式&#xff0c;它使用“對象”來組織代碼&#xff0c;這些對象能夠包含數據&#xff08;屬性&#xff09;以及功能&#xff08;方法&#xff09;。Scala…

【JVM-2.1】如何使用JMC監控工具:詳細步驟與實戰指南

Java Mission Control&#xff08;JMC&#xff09;是Oracle提供的一個高級圖形化監控工具&#xff0c;專為Java應用程序的性能分析和故障排查設計。JMC不僅提供了實時監控功能&#xff0c;還支持飛行記錄器&#xff08;Flight Recorder&#xff09;功能&#xff0c;能夠記錄JVM…

QT c++ 樣式 設置 標簽(QLabel)的漸變色美化

上一篇文章中描述了按鈕的純色&#xff0c;本文描述標簽的漸變色美化。 1.頭文件 #ifndef WIDGET_H #define WIDGET_H #include <QWidget> //#include "CustomButton.h"#include <QVBoxLayout> #include <QLinearGradient> #include <QLabel…

設計模式 行為型 觀察者模式(Observer Pattern)與 常見技術框架應用 解析

觀察者模式&#xff08;Observer Pattern&#xff09;是一種行為設計模式&#xff0c;它定義了一種一對多的依賴關系&#xff0c;讓多個觀察者對象同時監聽某一個主題對象。這個主題對象在狀態發生變化時&#xff0c;會通知所有觀察者對象&#xff0c;使它們能夠自動更新。 一…